:root {
  --bg: #f5f3ee;
  --surface: #ffffff;
  --text: #161616;
  --muted: #666666;
  --line: rgba(22, 22, 22, 0.12);
  --mint: #86d5c3;
  --orange: #ffa630;
  --violet: #5c5d8d;
  --earth: #9a6649;
  --soft-black: #1e1b1c;
  --max: 1440px;
  --radius: 24px;
  --shadow: 0 14px 40px rgba(0, 0, 0, 0.06);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Inter", system-ui, sans-serif;
  line-height: 1.55;
}

a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; display: block; }

.site-shell {
  width: min(calc(100% - 24px), var(--max));
  margin: 0 auto;
}

.site-header,
.site-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.site-header {
  padding: 20px 0;
  position: sticky;
  top: 0;
  backdrop-filter: blur(12px);
  background: rgba(245, 243, 238, 0.85);
  z-index: 20;
  border-bottom: 1px solid rgba(22, 22, 22, 0.04);
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 700;
}

.brand-mark {
  font-size: 1.5rem;
  letter-spacing: -0.03em;
}

.brand-text {
  font-size: 0.95rem;
  color: var(--muted);
}

.dot { font-weight: 800; }
.dot-mint { color: var(--mint); }
.dot-violet { color: var(--violet); }
.dot-earth { color: var(--earth); }

.site-nav {
  display: flex;
  gap: 18px;
  align-items: center;
}

.site-nav a {
  font-size: 0.95rem;
  color: var(--muted);
  padding-bottom: 2px;
  border-bottom: 1px solid transparent;
}

.site-nav a:hover,
.site-nav a.is-active {
  color: var(--text);
  border-color: currentColor;
}

.nav-toggle {
  display: none;
  border: 1px solid var(--line);
  background: var(--surface);
  border-radius: 999px;
  padding: 10px 14px;
}

main { padding: 24px 0 80px; }
.section { padding: 64px 0; }

.hero {
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: 28px;
  align-items: stretch;
  min-height: 70vh;
  padding: 56px 0 40px;
}

.hero-copy,
.editorial-card,
.entry-card,
.panel,
.package-card,
.contact-card,
.placeholder-media,
.manifesto-strip,
.story-layout,
.info-card {
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.hero-copy {
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  background: linear-gradient(160deg, rgba(255,255,255,0.92), rgba(255,255,255,0.65));
}

.hero h1,
.section h2,
.entry-card h3,
.package-card h3,
.contact-card h3,
.info-card h3 {
  font-size: clamp(2rem, 4vw, 4.6rem);
  line-height: 0.96;
  letter-spacing: -0.05em;
  margin: 0 0 18px;
}

.section h2 { font-size: clamp(1.8rem, 3.2vw, 3.1rem); }
.entry-card h3,
.package-card h3,
.contact-card h3,
.info-card h3 { font-size: clamp(1.5rem, 2.7vw, 2.3rem); }

.eyebrow,
.section-kicker,
.entry-kicker,
.micro-label,
.package-label {
  margin: 0 0 16px;
  font-size: 0.8rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

.lead {
  font-size: 1.1rem;
  color: #2e2e2e;
  max-width: 55ch;
}

.hero-actions,
.inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-weight: 600;
}

.btn-primary {
  background: var(--text);
  color: white;
}

.btn-secondary {
  background: transparent;
}

.editorial-card {
  padding: 32px;
  align-self: end;
}

.mini-manifesto,
.clean-list,
.package-list,
.contact-list,
.faq-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.mini-manifesto li,
.clean-list li,
.package-list li,
.contact-list li,
.faq-list li {
  padding: 14px 0;
  border-top: 1px solid var(--line);
}

.mini-manifesto li:first-child,
.clean-list li:first-child,
.package-list li:first-child,
.contact-list li:first-child,
.faq-list li:first-child { border-top: none; }

.intro-grid,
.split-section,
.story-layout,
.contact-grid,
.media-grid,
.stats-grid,
.dual-grid,
.package-grid,
.entry-detail-grid {
  display: grid;
  gap: 24px;
}

.intro-grid,
.split-section,
.dual-grid,
.contact-grid,
.entry-detail-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.package-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.project-entry-grid,
.stats-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }
.media-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.story-layout { grid-template-columns: 1.1fr 0.9fr; padding: 32px; }

.intro-block,
.panel,
.info-card,
.contact-card { padding: 28px; }
.entry-card { padding: 32px; min-height: 320px; display: flex; flex-direction: column; justify-content: space-between; }
.package-card { padding: 28px; }

.entry-mark {
  display: inline-block;
  font-weight: 800;
  letter-spacing: -0.04em;
  font-size: 2.5rem;
}

.entry-link {
  margin-top: 18px;
  font-weight: 700;
}

.entry-fineart { border-top: 6px solid var(--mint); }
.entry-pointlab { border-top: 6px solid var(--violet); }
.entry-storykeeper { border-top: 6px solid var(--earth); }

.placeholder-media {
  min-height: 300px;
  padding: 24px;
  display: grid;
  place-items: center;
  text-align: center;
  color: var(--muted);
  background:
    linear-gradient(135deg, rgba(255,255,255,0.92), rgba(255,255,255,0.55)),
    repeating-linear-gradient(45deg, transparent, transparent 14px, rgba(22,22,22,0.03) 14px, rgba(22,22,22,0.03) 28px);
}

.placeholder-media strong { display: block; color: var(--text); margin-bottom: 8px; }

.manifesto-strip {
  padding: 28px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
}

.price {
  font-size: 1.8rem;
  font-weight: 800;
  letter-spacing: -0.04em;
  margin: 12px 0 18px;
}

.muted { color: var(--muted); }
.accent-violet { color: var(--violet); }
.accent-earth { color: var(--earth); }
.accent-mint { color: #2d9680; }

.site-footer {
  padding: 28px 0 48px;
  border-top: 1px solid var(--line);
}

.footer-brand { margin: 0 0 6px; font-weight: 700; }
.footer-copy { margin: 0; color: var(--muted); }
.footer-links { display: flex; gap: 14px; flex-wrap: wrap; }

.page-hero {
  padding-top: 28px;
  min-height: auto;
}

.hero-badge {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  padding: 8px 12px;
  border-radius: 999px;
  margin-bottom: 18px;
  background: rgba(255,255,255,0.7);
}

.gallery-note {
  font-size: 0.95rem;
  color: var(--muted);
  margin-top: 10px;
}

.contact-list strong,
.faq-list strong {
  display: block;
  margin-bottom: 4px;
}

@media (max-width: 980px) {
  .hero,
  .intro-grid,
  .split-section,
  .story-layout,
  .contact-grid,
  .dual-grid,
  .entry-detail-grid,
  .package-grid,
  .project-entry-grid,
  .media-grid,
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .site-header { flex-wrap: wrap; }
  .nav-toggle { display: inline-flex; }
  .site-nav {
    width: 100%;
    display: none;
    flex-direction: column;
    align-items: flex-start;
    padding-bottom: 8px;
  }
  .site-nav.open { display: flex; }
}

@media (max-width: 640px) {
  .site-shell { width: min(calc(100% - 20px), var(--max)); }
  .hero-copy,
  .editorial-card,
  .entry-card,
  .panel,
  .package-card,
  .contact-card,
  .story-layout,
  .info-card,
  .manifesto-strip { padding: 22px; }
  .hero { padding-top: 24px; }
}



/* HOME REFINED */
.page-home {
  
}

.page-home a,
.page-home button {
  
}

/* cursor removed */ .custom-cursor {
  position: fixed;
  left: 0;
  top: 0;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: var(--violet);
  pointer-events: none;
  transform: translate(-50%, -50%);
  z-index: 9999;
  opacity: 0;
  transition: width 140ms ease, height 140ms ease, opacity 140ms ease, background 140ms ease;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.35);
}

/* cursor removed */ .custom-cursor.is-visible { opacity: 1; }
/* cursor removed */ .custom-cursor.is-hover {
  width: 22px;
  height: 22px;
}

.hero-home-refined {
  position: relative;
  overflow: visible;
  min-height: 82vh;
}

.hero-home-refined .hero-copy,
.hero-home-refined .hero-aside {
  position: relative;
  z-index: 2;
}

.floating-fragments {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.floating-fragment {
  position: absolute;
  margin: 0;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,0.8);
}

.floating-fragment img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* spread across the whole page, no overlaps */
.frag-1 { width: 180px; height: 230px; top: 6%; right: 2%; transform: rotate(-5deg); }
.frag-2 { width: 150px; height: 190px; top: 92%; left: -8px; transform: rotate(-4deg); }
.frag-3 { width: 170px; height: 210px; top: 165%; right: 4%; transform: rotate(6deg); }
.frag-4 { width: 145px; height: 180px; top: 235%; left: 3%; transform: rotate(-6deg); }
.frag-5 { width: 200px; height: 125px; top: 308%; right: 8%; transform: rotate(3deg); }

@media (max-width: 980px) {
  .page-home { cursor: auto; }
  .page-home a,
  .page-home button { cursor: pointer; }
  /* cursor removed */ .custom-cursor { display: none; }

  .hero-home-refined {
    min-height: auto;
  }

  .floating-fragments {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 20px;
  }

  .floating-fragment {
    position: relative;
    inset: auto;
    width: 100%;
    height: 180px;
    transform: none !important;
  }

  .frag-5 {
    grid-column: 1 / -1;
  }
}


/* FIX FRAGMENTS: no rotation, no overlap with text */
.floating-fragment {
  transform: none !important;
}

.frag-1 { top: 10%; right: 4%; }
.frag-2 { top: 80%; left: 2%; }
.frag-3 { top: 160%; right: 6%; }
.frag-4 { top: 240%; left: 4%; }
.frag-5 { top: 300%; right: 5%; }

.floating-fragments {
  z-index: 0;
}

.hero-copy,
.hero-aside,
.project-entry-grid,
.section {
  position: relative;
  z-index: 2;
}


/* HOME V5 - marquee banner instead of floating fragments */
.hero-home-refined {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 32px;
  align-items: end;
  min-height: auto;
  padding-top: 24px;
}

.hero-marquee {
  grid-column: 1 / -1;
  position: relative;
  overflow: hidden;
  width: 100%;
  padding: 6px 0 22px;
  margin-bottom: 4px;
}

/* removed gradient */ .hero-marquee::before,
/* removed gradient */ .hero-marquee::after {
  content: "";
  position: absolute;
  top: 0;
  width: 120px;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

/* removed gradient */ .hero-marquee::before {
  left: 0;
  background: linear-gradient(to right, var(--bg), rgba(247,245,241,0));
}

/* removed gradient */ .hero-marquee::after {
  right: 0;
  background: linear-gradient(to left, var(--bg), rgba(247,245,241,0));
}

.hero-marquee-track {
  display: flex;
  gap: 18px;
  width: max-content;
  animation: marqueeScroll 50s linear infinite;
}

.marquee-item {
  margin: 0;
  flex: 0 0 auto;
  width: 320px;
  height: 180px;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.9);
  box-shadow: var(--shadow);
}

.marquee-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.hero-copy-compact {
  min-height: 0;
  padding: 52px 48px;
  max-width: none;
}

.hero-copy-compact h1 {
  max-width: 7.6ch;
}

.hero-copy-compact .lead {
  max-width: 22ch;
}

.hero-home-refined .hero-aside {
  align-self: stretch;
  display: flex;
}

.hero-home-refined .editorial-card {
  width: 100%;
  min-height: 100%;
}

.floating-fragments,
.floating-fragment {
  display: none !important;
}

@keyframes marqueeScroll {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% - 9px)); }
}

@media (max-width: 1100px) {
  .hero-home-refined {
    grid-template-columns: 1fr;
  }

  .hero-home-refined .hero-aside {
    max-width: 520px;
  }
}

@media (max-width: 760px) {
  .hero-marquee {
    padding-bottom: 14px;
  }

  /* removed gradient */ .hero-marquee::before,
  /* removed gradient */ .hero-marquee::after {
    width: 48px;
  }

  .marquee-item {
    width: 240px;
    height: 140px;
    border-radius: 18px;
  }

  .hero-copy-compact {
    padding: 34px 26px;
  }
}

/* V6 refinements */

/* slower banner */
.hero-marquee-track {
  animation: marqueeScroll 90s linear infinite;
}

/* remove gradients visually */
.hero-marquee::before,
.hero-marquee::after {
  display:none;
}

/* less rounded + colored borders */
.marquee-item {
  border-radius: 12px;
  border: 1px solid var(--line);
}

/* subtle color accents */
.marquee-item:nth-child(3n+1){ border-color:#5c5d8d; }
.marquee-item:nth-child(3n+2){ border-color:#8fb7d8; }
.marquee-item:nth-child(3n+3){ border-color:#ffa630; }

/* better hero text spacing */
.hero-copy-compact {
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:18px;
}

.hero-copy-compact h1{
  line-height:1;
}

/* better right box spacing */
.hero-home-refined .editorial-card{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:32px;
  gap:16px;
}

.mini-manifesto{
  display:flex;
  flex-direction:column;
  gap:12px;
}

/* V7 adjustments */

/* Story keeper color fix */
:root {
  --storykeeper: #E97451;
}

/* hero text wider use */
.hero-copy-compact h1{
  max-width: none;
}

.hero-copy-compact .lead{
  max-width: none;
}

/* smaller approccio box */
.hero-home-refined .editorial-card{
  max-width: 360px;
}

/* second box */
.secondary-card{
  margin-top:16px;
  max-width:360px;
  padding:24px;
  border:1px solid var(--line);
  border-radius:16px;
}

/* FIX story keeper color globally */
.entry-storykeeper .dot,
.entry-storykeeper h3,
.entry-storykeeper .entry-mark{
  color:#E97451 !important;
}

.entry-storykeeper{
  border-color:#E97451 !important;
}

/* V9 Story Keeper fix */

/* remove orange border */
.entry-storykeeper{
  border-color: var(--line) !important;
}

/* make text black like others */
.entry-storykeeper h3,
.entry-storykeeper p,
.entry-storykeeper .entry-mark{
  color: var(--text) !important;
}

/* keep only accent elements orange */
.entry-storykeeper .dot{
  color:#E97451 !important;
}

.entry-storykeeper::before{
  background:#E97451 !important;
}

/* FIX top line story keeper */
.entry-storykeeper{
  border-top: 3px solid #E97451 !important;
}


/* POINT LAB REFINED */
.dot-orange { color: var(--orange); }

.page-pointlab .hero {
  min-height: auto;
}

.pointlab-hero {
  grid-template-columns: 1.2fr 0.8fr;
  align-items: end;
  gap: 24px;
  padding-top: 20px;
}

.pointlab-hero-top {
  grid-column: 1 / -1;
}

.marquee-shell {
  overflow: hidden;
  border-radius: var(--radius);
  margin-bottom: 4px;
}

.pointlab-marquee-track {
  display: flex;
  gap: 18px;
  width: max-content;
  animation: pointlabMarquee 72s linear infinite;
}

.marquee-item {
  margin: 0;
  flex: 0 0 auto;
  width: 320px;
  height: 180px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,0.82);
}

.marquee-item:nth-child(3n+1) { border-color: var(--orange); }
.marquee-item:nth-child(3n+2) { border-color: var(--violet); }
.marquee-item:nth-child(3n+3) { border-color: rgba(22,22,22,0.18); }

.marquee-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pointlab-entry-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.entry-pointlab-sport { border-top: 6px solid var(--orange); }
.entry-pointlab-pmi { border-top: 6px solid var(--violet); }

.pointlab-package-grid .package-card {
  position: relative;
  overflow: hidden;
  min-height: 100%;
}

.pointlab-card {
  padding-top: 24px;
}

.sport-card { border-top: 6px solid var(--orange); }
.pmi-card { border-top: 6px solid var(--violet); }

.sticker-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.price-sticker,
.micro-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: -0.02em;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.84);
}

.price-sticker {
  font-size: 1rem;
}

.accent-orange {
  border-color: rgba(255,166,48,0.45);
  color: #b36500;
}

.accent-violet-bg {
  border-color: rgba(92,93,141,0.32);
  color: var(--violet);
}

.fill-orange {
  background: rgba(255,166,48,0.14);
  border-color: rgba(255,166,48,0.2);
  color: #a55a00;
}

.fill-violet {
  background: rgba(92,93,141,0.1);
  border-color: rgba(92,93,141,0.18);
  color: var(--violet);
}

.card-meta {
  margin-top: 20px;
}

.compact-top {
  margin-top: 24px;
}

.before-after-slider {
  position: relative;
  overflow: hidden;
  min-height: 360px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,0.72);
}

.before-after-media {
  position: absolute;
  inset: 0;
  padding: 34px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  gap: 8px;
  color: white;
}

.before-pane {
  background:
    linear-gradient(180deg, rgba(30,27,28,0.05), rgba(30,27,28,0.72)),
    linear-gradient(135deg, #9c9c9c, #6f6f6f);
  clip-path: inset(0 50% 0 0);
}

.after-pane {
  background:
    linear-gradient(180deg, rgba(255,166,48,0.05), rgba(255,166,48,0.28)),
    linear-gradient(135deg, #5c5d8d, #ffa630);
  clip-path: inset(0 0 0 50%);
}

.before-after-media strong {
  font-size: clamp(2rem, 4vw, 4rem);
  letter-spacing: -0.04em;
}

.before-after-range {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: ew-resize;
  z-index: 4;
}

.before-after-divider {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: rgba(255,255,255,0.75);
  z-index: 3;
  transform: translateX(-50%);
}

.before-after-divider span {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  background: white;
  box-shadow: var(--shadow);
  transform: translate(-50%, -50%);
}

.pointlab-manifesto h2 {
  max-width: 12ch;
}

.reveal-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms ease, transform 700ms ease;
  will-change: opacity, transform;
}

.reveal-scroll.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-delay-1 { transition-delay: 80ms; }
.reveal-delay-2 { transition-delay: 160ms; }
.reveal-delay-3 { transition-delay: 240ms; }

@keyframes pointlabMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-50% - 9px)); }
}

@media (max-width: 980px) {
  .pointlab-hero,
  .pointlab-entry-grid {
    grid-template-columns: 1fr;
  }

  .marquee-item {
    width: 250px;
    height: 146px;
  }

  .before-pane { clip-path: inset(0 45% 0 0); }
  .after-pane { clip-path: inset(0 0 0 55%); }
}

@media (prefers-reduced-motion: reduce) {
  .pointlab-marquee-track {
    animation: none;
  }

  .reveal-scroll,
  .reveal-scroll.is-visible {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}


.big-dot{
  font-size:1.5em;
  margin-right:6px;
}

.pointlab-hero{
  grid-template-columns:1fr 1fr;
}

.before-after-media{
  position:relative;
}



/* fix alignment */
.pointlab-label{
  display:flex;
  align-items:center;
  gap:8px;
}

.pointlab-label .big-dot{
  transform:scale(1.4);
}

/* equal height boxes */
.pointlab-hero{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  align-items:stretch;
}

.pointlab-hero > div{
  height:100%;
}



/* V6 hero sizing fix */
.pointlab-hero{
  grid-template-columns: 1.5fr 0.5fr !important;
  align-items: stretch !important;
}

.pointlab-hero .hero-copy,
.pointlab-hero .editorial-card{
  height: 100%;
}

.pointlab-hero .editorial-card{
  min-height: 100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

@media (max-width: 980px){
  .pointlab-hero{
    grid-template-columns: 1fr !important;
  }
}


/* V6 before/after restore */
.before-after-media{
  justify-content: end !important;
  gap: 8px;
}

.after-pane strong{
  align-self: flex-start !important;
  position: static !important;
}

.before-pane{
  clip-path: inset(0 50% 0 0) !important;
}

.after-pane{
  clip-path: inset(0 0 0 50%) !important;
}


/* V7 interactive before/after */
.before-after-slider{
  margin-top: 24px;
}

.before-after-media.interactive-compare{
  position: relative;
  overflow: hidden;
  min-height: 420px;
  border-radius: var(--radius);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background: rgba(255,255,255,0.74);
  user-select: none;
  touch-action: none;
}

.before-after-media.interactive-compare .before-pane,
.before-after-media.interactive-compare .after-pane{
  position: absolute;
  inset: 0;
  padding: 34px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  gap: 10px;
  color: white;
}

.before-after-media.interactive-compare .before-pane{
  background:
    linear-gradient(180deg, rgba(30,27,28,0.06), rgba(30,27,28,0.72)),
    linear-gradient(135deg, #8b8b8b, #3a3a3a);
  clip-path: inset(0 50% 0 0);
  align-items: flex-start;
  text-align: left;
}

.before-after-media.interactive-compare .after-pane{
  background:
    linear-gradient(180deg, rgba(233,116,81,0.04), rgba(255,166,48,0.18)),
    linear-gradient(135deg, #c58a4a, #f0a94a);
  clip-path: inset(0 0 0 50%);
  align-items: flex-end;
  text-align: right;
}

.before-after-media.interactive-compare strong{
  font-size: clamp(3.2rem, 6vw, 4.4rem);
  letter-spacing: -0.05em;
  line-height: .95;
}

.before-after-media.interactive-compare span{
  max-width: 28ch;
  font-size: 1rem;
  line-height: 1.45;
}

.compare-divider{
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: rgba(255,255,255,0.85);
  transform: translateX(-50%);
  z-index: 4;
  pointer-events: none;
}

.compare-handle{
  position: absolute;
  left: 50%;
  top: 50%;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: white;
  box-shadow: var(--shadow);
  transform: translate(-50%, -50%);
}

.compare-handle::before,
.compare-handle::after{
  content: "";
  position: absolute;
  top: 50%;
  width: 8px;
  height: 8px;
  border-top: 2px solid rgba(22,22,22,0.65);
  border-right: 2px solid rgba(22,22,22,0.65);
}

.compare-handle::before{
  left: 12px;
  transform: translateY(-50%) rotate(225deg);
}

.compare-handle::after{
  right: 12px;
  transform: translateY(-50%) rotate(45deg);
}

@media (max-width: 980px){
  .before-after-media.interactive-compare{
    min-height: 340px;
  }

  .before-after-media.interactive-compare .before-pane,
  .before-after-media.interactive-compare .after-pane{
    padding: 24px;
  }

  .before-after-media.interactive-compare strong{
    font-size: clamp(2.4rem, 10vw, 3.4rem);
  }
}

/* Fix titolo box */
.pointlab-why h2{
  max-width: 36ch;
  line-height: 1.1;
}


/* V9 compare final fix */
.before-after-media.interactive-compare{
  position: relative !important;
  overflow: hidden !important;
  min-height: 420px !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--line) !important;
  box-shadow: var(--shadow) !important;
  background: rgba(255,255,255,0.74) !important;
  user-select: none !important;
  touch-action: none !important;
}

.before-after-media.interactive-compare .compare-layer{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.before-after-media.interactive-compare .before-pane{
  background:
    linear-gradient(180deg, rgba(30,27,28,0.06), rgba(30,27,28,0.72)),
    linear-gradient(135deg, #8b8b8b, #3a3a3a) !important;
  clip-path: inset(0 50% 0 0) !important;
  -webkit-clip-path: inset(0 50% 0 0) !important;
  z-index: 1 !important;
}

.before-after-media.interactive-compare .after-pane{
  background:
    linear-gradient(180deg, rgba(233,116,81,0.04), rgba(255,166,48,0.18)),
    linear-gradient(135deg, #c58a4a, #f0a94a) !important;
  clip-path: inset(0 0 0 50%) !important;
  -webkit-clip-path: inset(0 0 0 50%) !important;
  z-index: 2 !important;
}

.before-after-media.interactive-compare .compare-copy{
  position: absolute !important;
  bottom: 34px !important;
  color: white !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.before-after-media.interactive-compare .compare-copy-left{
  left: 34px !important;
  align-items: flex-start !important;
  text-align: left !important;
}

.before-after-media.interactive-compare .compare-copy-right{
  right: 34px !important;
  align-items: flex-end !important;
  text-align: right !important;
}

.before-after-media.interactive-compare strong{
  font-size: clamp(3.2rem, 6vw, 4.4rem) !important;
  letter-spacing: -0.05em !important;
  line-height: .95 !important;
}

.before-after-media.interactive-compare span{
  max-width: 28ch !important;
  font-size: 1rem !important;
  line-height: 1.45 !important;
}

.compare-divider{
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 50% !important;
  width: 2px !important;
  background: rgba(255,255,255,0.92) !important;
  transform: translateX(-50%) !important;
  z-index: 5 !important;
  pointer-events: none !important;
}

.compare-handle{
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  background: white !important;
  box-shadow: var(--shadow) !important;
  transform: translate(-50%, -50%) !important;
}

.compare-handle::before,
.compare-handle::after{
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  width: 8px !important;
  height: 8px !important;
  border-top: 2px solid rgba(22,22,22,0.65) !important;
  border-right: 2px solid rgba(22,22,22,0.65) !important;
}

.compare-handle::before{
  left: 12px !important;
  transform: translateY(-50%) rotate(225deg) !important;
}

.compare-handle::after{
  right: 12px !important;
  transform: translateY(-50%) rotate(45deg) !important;
}

@media (max-width: 980px){
  .before-after-media.interactive-compare{
    min-height: 340px !important;
  }
  .before-after-media.interactive-compare .compare-copy{
    bottom: 24px !important;
  }
  .before-after-media.interactive-compare .compare-copy-left{
    left: 24px !important;
  }
  .before-after-media.interactive-compare .compare-copy-right{
    right: 24px !important;
  }
  .before-after-media.interactive-compare strong{
    font-size: clamp(2.4rem, 10vw, 3.4rem) !important;
  }
}


/* V10 compare slider fix */
.before-after-media.compare-range-wrap{
  position: relative !important;
  overflow: hidden !important;
  min-height: 420px !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--line) !important;
  box-shadow: var(--shadow) !important;
  background: rgba(255,255,255,0.74) !important;
}

.before-after-media.compare-range-wrap .compare-layer{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

.before-after-media.compare-range-wrap .before-pane{
  background:
    linear-gradient(180deg, rgba(30,27,28,0.06), rgba(30,27,28,0.72)),
    linear-gradient(135deg, #8b8b8b, #3a3a3a) !important;
  clip-path: inset(0 50% 0 0) !important;
  -webkit-clip-path: inset(0 50% 0 0) !important;
  z-index: 1 !important;
}

.before-after-media.compare-range-wrap .after-pane{
  background:
    linear-gradient(180deg, rgba(233,116,81,0.04), rgba(255,166,48,0.18)),
    linear-gradient(135deg, #c58a4a, #f0a94a) !important;
  clip-path: inset(0 0 0 50%) !important;
  -webkit-clip-path: inset(0 0 0 50%) !important;
  z-index: 2 !important;
}

.before-after-media.compare-range-wrap .compare-copy{
  position: absolute !important;
  bottom: 34px !important;
  color: white !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.before-after-media.compare-range-wrap .compare-copy-left{
  left: 34px !important;
  align-items: flex-start !important;
  text-align: left !important;
}

.before-after-media.compare-range-wrap .compare-copy-right{
  right: 34px !important;
  align-items: flex-end !important;
  text-align: right !important;
}

.before-after-media.compare-range-wrap strong{
  font-size: clamp(3.2rem, 6vw, 4.4rem) !important;
  letter-spacing: -0.05em !important;
  line-height: .95 !important;
}

.before-after-media.compare-range-wrap span{
  max-width: 28ch !important;
  font-size: 1rem !important;
  line-height: 1.45 !important;
}

.before-after-media.compare-range-wrap .compare-divider{
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 50% !important;
  width: 2px !important;
  background: rgba(255,255,255,0.92) !important;
  transform: translateX(-50%) !important;
  z-index: 5 !important;
  pointer-events: none !important;
}

.before-after-media.compare-range-wrap .compare-handle{
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  background: white !important;
  box-shadow: var(--shadow) !important;
  transform: translate(-50%, -50%) !important;
}

.before-after-media.compare-range-wrap .compare-handle::before,
.before-after-media.compare-range-wrap .compare-handle::after{
  content: "" !important;
  position: absolute !important;
  top: 50% !important;
  width: 8px !important;
  height: 8px !important;
  border-top: 2px solid rgba(22,22,22,0.65) !important;
  border-right: 2px solid rgba(22,22,22,0.65) !important;
}

.before-after-media.compare-range-wrap .compare-handle::before{
  left: 12px !important;
  transform: translateY(-50%) rotate(225deg) !important;
}

.before-after-media.compare-range-wrap .compare-handle::after{
  right: 12px !important;
  transform: translateY(-50%) rotate(45deg) !important;
}

/* actual working slider */
.before-after-media.compare-range-wrap .compare-range{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  opacity: 0.001 !important;
  z-index: 10 !important;
  cursor: ew-resize !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  background: transparent !important;
}

.before-after-media.compare-range-wrap .compare-range::-webkit-slider-thumb{
  -webkit-appearance: none;
  appearance: none;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: transparent;
  border: 0;
}

.before-after-media.compare-range-wrap .compare-range::-moz-range-thumb{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: transparent;
  border: 0;
}

@media (max-width: 980px){
  .before-after-media.compare-range-wrap{
    min-height: 340px !important;
  }
  .before-after-media.compare-range-wrap .compare-copy{
    bottom: 24px !important;
  }
  .before-after-media.compare-range-wrap .compare-copy-left{
    left: 24px !important;
  }
  .before-after-media.compare-range-wrap .compare-copy-right{
    right: 24px !important;
  }
  .before-after-media.compare-range-wrap strong{
    font-size: clamp(2.4rem, 10vw, 3.4rem) !important;
  }
}


/* V11 restore original working before/after slider */
.before-after-slider{
  margin-top: 24px;
}

.before-after-media{
  position: relative !important;
  overflow: hidden !important;
  min-height: 360px !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--line) !important;
  box-shadow: var(--shadow) !important;
  background: rgba(255,255,255,0.72) !important;
}

.before-pane,
.after-pane{
  position: absolute !important;
  inset: 0 !important;
  padding: 34px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: end !important;
  gap: 8px !important;
  color: white !important;
}

.before-pane{
  background:
    linear-gradient(180deg, rgba(30,27,28,0.05), rgba(30,27,28,0.72)),
    linear-gradient(135deg, #9c9c9c, #6f6f6f) !important;
  clip-path: inset(0 50% 0 0) !important;
  -webkit-clip-path: inset(0 50% 0 0) !important;
}

.after-pane{
  background:
    linear-gradient(180deg, rgba(255,166,48,0.05), rgba(255,166,48,0.28)),
    linear-gradient(135deg, #5c5d8d, #ffa630) !important;
  clip-path: inset(0 0 0 50%) !important;
  -webkit-clip-path: inset(0 0 0 50%) !important;
  align-items: flex-end !important;
  text-align: right !important;
}

.before-pane strong,
.after-pane strong{
  font-size: clamp(2rem, 4vw, 4rem) !important;
  letter-spacing: -0.04em !important;
}

.before-after-range{
  position: absolute !important;
  inset: 0 !important;
  opacity: 0.001 !important;
  z-index: 5 !important;
  cursor: ew-resize !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  background: transparent !important;
}

.before-after-range::-webkit-slider-thumb{
  -webkit-appearance: none;
  appearance: none;
  width: 54px;
  height: 54px;
  border: 0;
  background: transparent;
}
.before-after-range::-moz-range-thumb{
  width: 54px;
  height: 54px;
  border: 0;
  background: transparent;
}

.before-after-divider{
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 50% !important;
  width: 2px !important;
  background: rgba(255,255,255,0.75) !important;
  z-index: 4 !important;
  transform: translateX(-50%) !important;
}

.before-after-divider span{
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 54px !important;
  height: 54px !important;
  border-radius: 999px !important;
  background: white !important;
  box-shadow: var(--shadow) !important;
  transform: translate(-50%, -50%) !important;
}

@media (max-width: 980px){
  .before-after-media{
    min-height: 320px !important;
  }
  .before-pane,
  .after-pane{
    padding: 24px !important;
  }
}

/* Toggle */
.before-after-toggle{
  margin-top:40px;
}

.toggle-buttons{
  display:flex;
  gap:10px;
  margin-bottom:20px;
}

.toggle-btn{
  padding:10px 20px;
  border-radius:20px;
  border:1px solid var(--line);
  background:transparent;
  cursor:pointer;
}

.toggle-btn.active{
  background:black;
  color:white;
}

.toggle-panel{
  display:none;
  padding:30px;
  border:1px solid var(--line);
  border-radius:20px;
  background:white;
}

.toggle-panel.active{
  display:block;
}

/* Banner */
.mid-banner{
  overflow:hidden;
  margin:60px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.banner-track{
  display:flex;
  gap:40px;
  animation: scrollBanner 20s linear infinite;
}

@keyframes scrollBanner{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}


/* V13 toggle image layout */
.before-after-toggle{
  margin-top: 36px;
}

.toggle-content{
  margin-top: 18px;
}

.toggle-panel{
  padding: 22px;
}

.toggle-panel.active{
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 22px;
  align-items: stretch;
}

.toggle-media{
  min-height: 300px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.82);
  box-shadow: var(--shadow);
}

.toggle-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.toggle-copy{
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 12px;
}

.toggle-copy h3{
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.toggle-copy p{
  margin: 0;
  line-height: 1.75;
}

.pointlab-mid-marquee{
  margin-top: 18px;
  margin-bottom: 18px;
}

@media (max-width: 980px){
  .toggle-panel.active{
    grid-template-columns: 1fr;
  }

  .toggle-media{
    min-height: 220px;
  }
}

/* v5 footer */
.site-footer {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 16px;
}

.footer-links,
.footer-social {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

.footer-social a {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--line);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.footer-legal {
  margin: 0;
  color: var(--muted);
  font-size: .9rem;
}
.footer-icon-link svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.footer-icon-link[aria-label="Facebook"] svg { fill: currentColor; stroke: none; }


/* v6 footer layout */
.site-footer {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
  text-align: left;
}
.footer-brand-block {
  display: grid;
  gap: 8px;
  justify-self: start;
}
.footer-brand { margin: 0; font-weight: 700; }
.footer-copy { display: none; }
.footer-social {
  display: flex;
  gap: 16px;
  justify-content: center;
  justify-self: center;
}
.footer-links {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  justify-content: flex-end;
  justify-self: end;
}
.footer-legal {
  margin: 0;
  color: var(--muted);
  font-size: .92rem;
}
@media (max-width: 980px) {
  .site-footer {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
  .footer-brand-block,
  .footer-social,
  .footer-links { justify-self: center; justify-content: center; }
}


/* v6 point lab manifesto rebalance */
.pointlab-manifesto {
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  align-items: center;
  gap: 28px;
}
.pointlab-manifesto h2 {
  max-width: 8.8ch;
}
.pointlab-manifesto .muted {
  max-width: 28ch;
  line-height: 1.4;
}
@media (max-width: 980px) {
  .pointlab-manifesto { grid-template-columns: 1fr; }
}


/* --- banner zoom lightbox --- */
.marquee-item img{
  cursor: zoom-in;
}

.banner-lightbox{
  position: fixed;
  inset: 0;
  background: rgba(15, 15, 15, 0.82);
  backdrop-filter: blur(6px);
  display: grid;
  place-items: center;
  padding: 24px;
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease;
  z-index: 140;
}

.banner-lightbox.is-open{
  opacity: 1;
  pointer-events: auto;
}

.banner-lightbox__dialog{
  position: relative;
  width: min(1200px, calc(100vw - 64px));
  max-height: calc(100vh - 64px);
  display: grid;
  place-items: center;
}

.banner-lightbox__img{
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: calc(100vh - 64px);
  border-radius: 24px;
  box-shadow: 0 26px 80px rgba(0,0,0,.35);
  background: rgba(255,255,255,.04);
}

.banner-lightbox__close{
  position: absolute;
  top: 10px;
  right: 10px;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(0,0,0,.3);
  color: #fff;
  border-radius: 999px;
  cursor: pointer;
  font-size: 1.4rem;
  line-height: 1;
}

@media (max-width: 760px){
  .banner-lightbox{
    padding: 14px;
  }
  .banner-lightbox__dialog{
    width: min(100vw - 20px, 100%);
    max-height: calc(100vh - 20px);
  }
  .banner-lightbox__img{
    max-height: calc(100vh - 20px);
    border-radius: 18px;
  }
}


.pointlab-hero > .hero-copy,
.pointlab-hero > .editorial-card,
.storykeeper-hero > .hero-copy,
.storykeeper-hero > .editorial-card {
  align-self: stretch;
}
.pointlab-mosaic-shell .pointlab-hero-top,
.storykeeper-mosaic-shell .pointlab-hero-top {
  grid-column: auto;
}
.pointlab-mosaic-shell .media-mosaic,
.storykeeper-mosaic-shell .media-mosaic {
  margin-top: 8px;
}


.hero-badge--logo {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0;
  background: transparent;
  border: 0;
  min-height: auto;
}
.hero-badge__logo {
  display: block;
  height: 26px;
  width: auto;
}
.hero-badge__logo--storykeeper {
  height: 24px;
}
.brand-logo-pill {
  display: inline-flex;
  align-items: center;
  min-height: 46px;
}
.brand-logo-pill img {
  display: block;
  height: 24px;
  width: auto;
}
.receipt-brand-logo {
  display: block;
  height: 22px;
  width: auto;
  max-width: 220px;
}
@media (max-width: 900px) {
  .hero-badge__logo { height: 22px; }
  .hero-badge__logo--storykeeper { height: 20px; }
  .brand-logo-pill img { height: 21px; }
  .receipt-brand-logo { height: 18px; max-width: 180px; }
}


.pointlab-builder-section {
  padding-top: 20px;
}

.pointlab-builder-layout {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 24px;
  align-items: start;
}

.pointlab-builder-panel,
.pointlab-builder-summary {
  padding: 28px;
}

.pointlab-builder-panel {
  display: grid;
  gap: 28px;
}

.pointlab-builder-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: start;
  padding-top: 4px;
}

.pointlab-builder-step + .pointlab-builder-step {
  border-top: 1px solid var(--line);
  padding-top: 24px;
}

.pointlab-builder-step__label {
  margin: 0;
  font-size: 1rem;
  letter-spacing: 0.2em;
  color: var(--violet);
  font-weight: 700;
}

.pointlab-choice-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pointlab-pill,
.pointlab-option,
.pointlab-check {
  display: block;
}

.pointlab-pill input,
.pointlab-option input,
.pointlab-check input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.pointlab-pill span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.84);
  font-weight: 600;
  cursor: pointer;
}

.pointlab-pill input:checked + span {
  border-color: var(--violet);
  background: rgba(92, 93, 141, 0.12);
  color: var(--soft-black);
}

.pointlab-package-set,
.pointlab-extras-set {
  display: grid;
  gap: 12px;
}

.pointlab-package-set[hidden],
.pointlab-extras-set[hidden] {
  display: none !important;
}

.pointlab-option span,
.pointlab-check span {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 14px;
  width: 100%;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.82);
  cursor: pointer;
}

.pointlab-option span strong,
.pointlab-check span strong {
  white-space: nowrap;
}

.pointlab-option input:checked + span {
  border-color: var(--violet);
  background: rgba(92, 93, 141, 0.1);
  box-shadow: inset 0 0 0 1px rgba(92, 93, 141, 0.08);
}

.pointlab-check input:checked + span {
  border-color: var(--orange);
  background: rgba(255, 166, 48, 0.1);
  box-shadow: inset 0 0 0 1px rgba(255, 166, 48, 0.08);
}

.pointlab-summary-head h3 {
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  margin-bottom: 12px;
}

.pointlab-summary-card {
  margin-top: 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255,255,255,0.86);
  overflow: hidden;
}

.pointlab-summary-line,
.pointlab-summary-block {
  padding: 18px 20px;
  border-top: 1px solid var(--line);
}

.pointlab-summary-line:first-child {
  border-top: none;
}

.pointlab-summary-line {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.pointlab-summary-line span,
.pointlab-summary-block__title {
  color: var(--muted);
  font-size: 0.85rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.pointlab-summary-list {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: grid;
  gap: 10px;
}

.pointlab-summary-list li {
  padding-top: 10px;
  border-top: 1px solid rgba(22,22,22,0.08);
}

.pointlab-summary-list li:first-child {
  border-top: none;
  padding-top: 0;
}

.pointlab-summary-note {
  margin-top: 18px;
  color: var(--muted);
}

@media (max-width: 980px) {
  .pointlab-builder-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .pointlab-builder-panel,
  .pointlab-builder-summary {
    padding: 22px;
  }

  .pointlab-builder-step {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .pointlab-option span,
  .pointlab-check span {
    flex-direction: column;
    align-items: flex-start;
  }

  .pointlab-summary-line {
    flex-direction: column;
  }
}
