* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

:root {
  --bg: #f7f3ec;
  --bg-2: #edf4fb;
  --surface: rgba(255,255,255,0.72);
  --surface-2: rgba(255,255,255,0.86);
  --surface-warm: #fffaf2;
  --text: #151b24;
  --muted: #586574;
  --quiet: #7c8795;
  --line: rgba(36,49,70,0.13);
  --line-strong: rgba(36,49,70,0.24);
  --accent: #2f6fae;
  --accent-strong: #174f91;
  --purple: #7257f0;
  --green: #5f8f2f;
  --shadow: rgba(64,78,101,0.18);
  --radius: 30px;
  --stage-width: 1180px;
  --font: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', Inter, system-ui, sans-serif;
}

html {
  scroll-behavior: smooth;
  background: var(--bg-2);
  overflow-x: hidden;
  overscroll-behavior-x: none;
  overscroll-behavior-y: auto;
}

body {
  min-height: 100vh;
  position: relative;
  isolation: isolate;
  font-family: var(--font);
  background: linear-gradient(180deg, rgba(255,238,206,0.10) 0%, rgba(245,229,212,0.10) 42%, rgba(222,237,249,0.10) 100%), #fff;
  color: var(--text);
  overflow-x: hidden;
  overscroll-behavior-x: none;
  overscroll-behavior-y: auto;
  -webkit-font-smoothing: antialiased;
}

.showcase-topbar,
main {
  position: relative;
  z-index: 2;
}

main {
  padding-bottom: clamp(4.5rem, 8vw, 7rem);
}

body::before,
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
}

body::before {
  z-index: 0;
  background:
    radial-gradient(circle at 50% 24%, rgba(255,255,255,0.10), transparent 38rem),
    linear-gradient(180deg, rgba(255,238,206,0.10), rgba(222,237,249,0.10));
}

body::after {
  z-index: 1;
  background:
    linear-gradient(rgba(33,47,68,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(33,47,68,0.06) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.34), transparent 80%);
}

.lava-lamp-bg {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
  opacity: 0.92;
}

.lava-lamp-canvas {
  display: block;
  width: 100%;
  height: 100%;
  image-rendering: auto;
}


a,
button,
summary,
[role="button"] {
  -webkit-tap-highlight-color: transparent;
}

a {
  color: var(--text);
  text-decoration: none;
}

a:hover {
  color: var(--accent);
}

a:focus-visible {
  outline: 3px solid rgba(185,216,255,0.54);
  outline-offset: 4px;
  border-radius: 10px;
}

.visually-hidden,
.cylinder-item__sr-meta {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.skip-link {
  position: absolute;
  top: -4rem;
  left: 1rem;
  z-index: 10;
  background: var(--accent-strong);
  color: #fff;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  font-weight: 800;
}

.skip-link:focus {
  top: 1rem;
}

.showcase-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  width: 100%;
  margin: 0;
  padding: 0.9rem max(2rem, calc((100vw - var(--stage-width)) / 2));
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.35rem;
  color: var(--muted);
  border: 0;
  border-bottom: 1px solid rgba(220, 227, 234, 0.82);
  border-radius: 0;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  --header-progress: 0;
  transform: translateY(calc((var(--header-progress) - 1) * 100%));
  opacity: var(--header-progress);
  will-change: transform, opacity;
  transition: none;
}

.identity {
  display: inline-flex;
  align-items: center;
  min-height: 1.45rem;
  padding: 0;
  border-radius: 0;
  font-weight: 850;
  letter-spacing: -0.035em;
  background: transparent;
  box-shadow: none;
}

.showcase-topbar nav {
  display: flex;
  align-items: center;
  gap: 1.35rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  font-size: 0.94rem;
  perspective: none;
}

.showcase-topbar a {
  color: rgba(21,27,36,0.78);
}

.showcase-topbar nav a {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 1.45rem;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  text-shadow: none;
  transform: none;
  transition: color 180ms ease;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}



.showcase-topbar a:hover,
.showcase-topbar a:focus-visible {
  color: var(--accent-strong);
}

.showcase-topbar nav a:hover,
.showcase-topbar nav a:focus-visible {
  color: var(--accent-strong);
}

.hero,
.demo-index,
.scope-note {
  width: min(100% - 2rem, var(--stage-width));
  margin-inline: auto;
}

.hero {
  min-height: min(860px, calc(100svh - 72px));
  display: flex;
  align-items: center;
  padding: clamp(3rem, 7vw, 6.2rem) 0 clamp(3.2rem, 7vw, 6rem);
}

.hero--trsnparent_wheel {
  min-height: 100svh;
  padding-top: clamp(2.6rem, 5vw, 5rem);
  padding-bottom: clamp(3rem, 5vw, 5.4rem);
  isolation: isolate;
}

.hero--proof {
  isolation: isolate;
}

.hero-layout {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.55rem, 4vw, 3rem);
  align-items: center;
  justify-items: center;
}

.hero-copy {
  max-width: 1120px;
  text-align: center;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.73rem;
  font-weight: 850;
  color: var(--accent);
}


h1,
h2,
h3 {
  letter-spacing: -0.067em;
  line-height: 0.96;
}

h1 {
  max-width: 1120px;
  font-size: clamp(3rem, 6.35vw, 6.75rem);
  margin: 0 auto;
  text-wrap: balance;
  overflow-wrap: break-word;
}

h2 {
  font-size: clamp(2.15rem, 5vw, 5.25rem);
  margin: 0.7rem 0 1rem;
}

h3 {
  font-size: clamp(1.8rem, 3vw, 3.45rem);
  margin: 0.65rem 0 1rem;
}

p {
  color: var(--muted);
  line-height: 1.68;
}

.hero-lead {
  max-width: 720px;
  color: var(--muted);
  font-size: clamp(1.04rem, 2vw, 1.25rem);
}

.decision-grid strong,
.proof-line {
  display: block;
  color: var(--text);
}

.decision-grid span {
  display: block;
  color: var(--muted);
  line-height: 1.55;
}

#strategy {
  --flow-paper: #fffaf2;
  --flow-ink: #26364c;
  --flow-blue: #2f6fae;
  --flow-violet: #7257f0;
  --flow-coral: #d97858;
  --flow-skin: #c98963;
  --flow-spark: #d99a28;
  --flow-mark: rgba(255, 250, 242, 0.96);
  --idea-blue: #356fb5;
  --idea-coral: #d9795d;
  --idea-green: #65923a;
}

#strategy .decision-grid strong {
  margin-bottom: 0.58rem;
  letter-spacing: 0.012em;
}

#strategy .decision-grid span {
  line-height: 1.62;
}

.process-flow {
  margin-top: clamp(1.8rem, 4vw, 2.6rem);
  padding-top: clamp(1.35rem, 3vw, 2rem);
  border-top: 1px solid rgba(36,49,70,0.12);
}

.process-flow h3 {
  max-width: 760px;
  margin: 0;
  font-size: clamp(1.55rem, 3vw, 2.65rem);
  letter-spacing: -0.035em;
  line-height: 1.04;
}

.decision-grid--steps {
  margin-top: 1rem;
}

.decision-grid--steps article {
  min-width: 0;
}

.process-illustration {
  position: relative;
  width: min(100%, var(--process-art-width, 13rem));
  height: var(--process-art-box, 13rem);
  margin-bottom: 0.85rem;
  pointer-events: none;
  transform: translate3d(var(--process-art-x, 0rem), var(--process-art-y, 0rem), 0);
  transform-origin: center;
}

.process-illustration__stage {
  position: relative;
  width: 100%;
  height: 100%;
  transform: scale(var(--process-art-scale, 1));
  transform-origin: center;
}

.process-illustration svg,
.process-illustration img {
  display: block;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.process-illustration img {
  object-fit: contain;
}

.process-sparkle-layer {
  position: absolute;
  inset: 0;
  z-index: 2;
}

.process-sparkle {
  fill: var(--flow-spark);
  opacity: 0.36;
  transform-box: fill-box;
  transform-origin: center;
  animation: processSparkle 5.2s cubic-bezier(0.22, 1, 0.36, 1) infinite;
}

.process-sparkle--one {
  animation-duration: 4.7s;
  animation-delay: -0.4s;
}

.process-sparkle--two {
  animation-duration: 6.3s;
  animation-delay: -2.1s;
}

.process-sparkle--three {
  animation-duration: 5.6s;
  animation-delay: -3.4s;
}

@keyframes processSparkle {
  0%, 9%, 100% {
    opacity: 0.34;
    transform: scale(0.72) rotate(-8deg);
  }

  14% {
    opacity: 1;
    transform: scale(1.15) rotate(4deg);
  }

  23% {
    opacity: 0.48;
    transform: scale(0.88) rotate(-2deg);
  }
}

.hero-case {
  position: relative;
  width: min(100%, 1080px);
  min-width: 0;
  margin-inline: auto;
}

.hero-case::before {
  content: '';
  position: absolute;
  inset: -10% 8% 4%;
  z-index: 0;
  border-radius: 40px;
  background: radial-gradient(circle at 50% 35%, rgba(127,173,225,0.30), transparent 58%);
  pointer-events: none;
}

.hero-case .demo-card {
  z-index: 1;
}

.section-heading {
  max-width: 780px;
  margin-bottom: 2rem;
}

.demo-index,
.scope-note {
  margin-bottom: clamp(4.5rem, 8vw, 7rem);
}

.demo-card,
.scope-note {
  position: relative;
  min-height: 380px;
  padding: clamp(1.15rem, 3vw, 1.85rem);
  border: 1px solid rgba(36,49,70,0.11);
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.30), rgba(255,255,255,0.08)),
    var(--card-glass, rgba(255,255,255,0.16));
  box-shadow:
    0 32px 86px rgba(64,78,101,0.13),
    inset 0 1px 0 rgba(255,255,255,0.68),
    inset 0 -1px 0 rgba(36,49,70,0.035);
  overflow: hidden;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.demo-card::before,
.scope-note::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 76% 8%, rgba(255,255,255,0.34), transparent 14rem),
    linear-gradient(122deg, rgba(255,255,255,0.18), transparent 28%, rgba(255,255,255,0.055) 44%, transparent 72%);
  pointer-events: none;
}

.demo-card {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  min-height: 500px;
  contain: layout paint;
  cursor: pointer;
}

.demo-card--featured {
  min-height: 560px;
}

.demo-card > *,
.scope-note > * {
  position: relative;
  z-index: 1;
}

.demo-card__full-link {
  position: absolute;
  inset: -1px;
  z-index: 4;
  display: block;
  border-radius: inherit;
  color: inherit;
  cursor: pointer;
}

.demo-card__full-link:focus-visible {
  outline: 3px solid rgba(47,111,174,0.46);
  outline-offset: -8px;
  border-radius: inherit;
}

.demo-card:focus-within {
  border-color: rgba(47,111,174,0.30);
}

.site-shot {
  position: relative;
  z-index: 1;
  width: 100%;
  aspect-ratio: 72 / 49;
  margin-bottom: 1rem;
  border: 1px solid rgba(36,49,70,0.14);
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255,255,255,0.26);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.64), 0 20px 46px rgba(64,78,101,0.10);
}

.site-shot img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.site-shot--live-demo {
  background: #f4ead9;
  isolation: isolate;
}

.live-preview-shell {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: #f4ead9;
}

.live-demo-frame {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 192%;
  height: 192%;
  border: 0;
  background: #f4ead9;
  pointer-events: none;
  transform: scale(0.52);
  transform-origin: top left;
}

.live-preview-fallback {
  display: none !important;
}

.case-study-link {
  display: grid;
  min-height: 100%;
  grid-template-columns: minmax(0, 1.3fr) minmax(270px, 0.7fr);
  gap: clamp(1.05rem, 3vw, 2.15rem);
  align-items: center;
  color: inherit;
}

.case-study-link .site-shot {
  grid-row: 1 / span 4;
  margin-bottom: 0;
}

.case-study-link h3 {
  margin: 0;
}

.case-study-link .open-live {
  margin-top: 0.65rem;
}

.demo-card--case-study {
  min-height: 0;
  padding: clamp(1rem, 2.4vw, 1.45rem);
  --card-glass:
    linear-gradient(145deg, rgba(223,239,255,0.28), rgba(239,231,255,0.18)),
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(214,228,246,0.12));
}

.demo-card--case-study .site-shot {
  aspect-ratio: 72 / 49;
}

.open-live,
.demo-action-label,
.text-link {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  margin-top: 1.25rem;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 0.72rem 1rem;
  color: var(--text);
  font-weight: 850;
  background: rgba(255,255,255,0.18);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.proof-line {
  margin-top: 0.35rem;
  color: #26313f;
  font-weight: 740;
}

.demo-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.35rem);
}

.demo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: auto;
}

.demo-card--bright {
  --card-glass:
    linear-gradient(145deg, rgba(236,255,187,0.28), rgba(255,255,255,0.16)),
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(205,226,122,0.12));
}
.demo-card--soft {
  --card-glass:
    linear-gradient(145deg, rgba(255,222,242,0.28), rgba(255,255,255,0.16)),
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(226,195,221,0.12));
}
.demo-card--green {
  --card-glass:
    linear-gradient(145deg, rgba(224,250,190,0.28), rgba(255,255,255,0.16)),
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(190,224,170,0.12));
}
.demo-card--legal {
  --card-glass:
    linear-gradient(145deg, rgba(255,238,222,0.28), rgba(255,255,255,0.16)),
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(189,118,96,0.12));
}
.demo-card--creative {
  --card-glass:
    linear-gradient(145deg, rgba(232,212,255,0.30), rgba(255,255,255,0.16)),
    linear-gradient(145deg, rgba(255,255,255,0.18), rgba(212,193,239,0.13));
}

.scope-note {
  min-height: auto;
  --card-glass: linear-gradient(145deg, rgba(255,255,255,0.22), rgba(225,238,252,0.12));
}


.decision-note {
  margin-top: -1rem;
}

#contact {
  margin-bottom: 0;
}

.decision-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
  margin-top: 1.4rem;
}

.decision-grid article {
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 1rem;
  background: rgba(255,255,255,0.20);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .process-sparkle {
    animation: none !important;
    opacity: 0.86;
  }
}

@media (max-width: 960px) {
  .demo-grid,
  .decision-grid,
  .case-study-link {
    grid-template-columns: 1fr;
  }

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

  .case-study-link .site-shot {
    grid-row: auto;
  }
}

@media (max-width: 680px) {
  .showcase-topbar {
    align-items: center;
    flex-direction: row;
    padding: 0.62rem 1rem;
    gap: 0.85rem;
  }

  .identity {
    flex: 1 1 auto;
    min-width: 0;
    font-size: 0.92rem;
    white-space: nowrap;
  }

  .showcase-topbar nav {
    flex: 0 0 auto;
    justify-content: flex-end;
    flex-wrap: nowrap;
    gap: 0.78rem;
    font-size: 0.86rem;
    white-space: nowrap;
  }

  .hero {
    padding-top: 2.2rem;
    min-height: auto;
  }

  h1 {
    font-size: clamp(2.65rem, 12vw, 3.45rem);
  }

  body::after,
  .hero-case::before {
    display: none;
  }

  .demo-card,
  .demo-card--featured,
  .demo-card--case-study {
    min-height: 0;
  }

  .site-shot {
    border-radius: 18px;
  }
}

/* =============================================
   PHONE-SPECIFIC RULES (≤ 480px)
   ============================================= */
@media (max-width: 480px) {
  /* Move SVG illustrations BELOW the text block */
  .decision-grid--steps {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .decision-grid--steps article {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 0.75rem;
  }

  /* Reset illustration — drop SVG below content, individual classes handle scale/position */
  .process-illustration {
    --process-art-x: 0rem;
    --process-art-y: 0rem;
    --process-art-scale: 3rem;
    --process-art-width: 8rem;
    --process-art-box: 8rem;
    transform: translate3d(0, 0, 0) !important;
    margin: 0.75rem auto 0;
  }

  .process-illustration__stage {
    transform: scale(var(--process-art-scale, 0.85)) !important;
  }

  .decision-grid--steps strong {
    font-size: 0.95rem;
    margin-top: 0.4rem;
  }

  .decision-grid--steps span {
    font-size: 0.82rem;
    line-height: 1.35;
  }

  /* INDIVIDUAL SVG CONTROLS — each SVG and text block has its own section */

  /* ===== Three starting ideas ===== */
  /* Text spacing */
  .decision-grid--steps .process-illustration--ideas ~ strong { margin-top: 2rem; }
  .decision-grid--steps .process-illustration--ideas ~ span  { margin-top: 0.3rem; }
  /* SVG spacing from text above */
  .decision-grid--steps .process-illustration--ideas {
    transform: translate3d(0, 0, 0) scale(1.2) !important;
    margin: -3.5rem auto 0;
    width: 8rem !important;
    height: 10rem !important;
  }

  /* ===== Shape it together ===== */
  /* Text spacing */
  .decision-grid--steps .process-illustration--together ~ strong { margin-top: 1rem; }
  .decision-grid--steps .process-illustration--together ~ span  { margin-top: 0.3rem; }
  /* SVG spacing from text above */
  .decision-grid--steps .process-illustration--together {
    transform: translate3d(0, 0, 0) scale(1.2) !important;
    margin: 0rem auto 0;
    width: 8rem !important;
    height: 10rem !important;
  }

  /* ===== Built and delivered ===== */
  /* Text spacing */
  .decision-grid--steps .process-illustration--delivered ~ strong { margin-top:-2rem; }
  .decision-grid--steps .process-illustration--delivered ~ span  { margin-top: 0rem; }
  /* SVG spacing from text above */
  .decision-grid--steps .process-illustration--delivered {
    transform: translate3d(0, 0, 0) scale(1.2) !important;
    margin: 0rem auto 0;
    width: 8rem !important;
    height: 10rem !important;
  }
}


/* SEO/AEO compact dropdown service FAQ */
.hero-layout--trsnparent_wheel {
  gap: clamp(2.1rem, 4.8vw, 4rem);
}

.trsnparent_wheel-stage {
  position: relative;
  width: min(100%, 1120px);
  margin-inline: auto;
  display: grid;
  justify-items: center;
  gap: clamp(0.35rem, 1vw, 0.75rem);
}

.carousel-drag-hint {
  position: absolute;
  left: 50%;
  top: clamp(11rem, 22vw, 16rem);
  z-index: 80;
  transform: translate(-50%, -50%) scale(0.96);
  opacity: 0;
  pointer-events: none;
  padding: 0.9rem 1.22rem;
  border: 1px solid rgba(36,49,70,0.16);
  border-radius: 999px;
  background: rgba(255,255,255,0.94);
  color: #101822;
  font-size: clamp(0.96rem, 1.35vw, 1.12rem);
  font-weight: 750;
  letter-spacing: -0.025em;
  box-shadow: 0 18px 34px rgba(31,42,58,0.26), 0 0 0 8px rgba(255,255,255,0.22);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition: opacity 520ms ease, transform 420ms ease;
}

.carousel-drag-hint.is-visible {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  animation: carouselHintShake 1.8s ease-in-out 0.25s infinite;
}

@keyframes carouselHintShake {
  0%, 78%, 100% { transform: translate(-50%, -50%) scale(1); }
  83% { transform: translate(calc(-50% - 4px), -50%) scale(1); }
  88% { transform: translate(calc(-50% + 4px), -50%) scale(1); }
  93% { transform: translate(calc(-50% - 2px), -50%) scale(1); }
}

.carousel-centre-label {
  position: relative;
  z-index: 40;
  margin: clamp(-1.65rem, -2.15vw, -1.05rem) auto 0;
  text-align: center;
  color: #7f8a96;
  font-family: var(--font);
  font-size: clamp(0.92rem, 1.55vw, 1.38rem);
  line-height: 1;
  font-weight: 400;
  letter-spacing: -0.015em;
}

.view-home {
  width: min(100%, 1120px);
  min-height: clamp(430px, 54vw, 620px);
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 2500px;
  overflow: visible;
  cursor: grab;
  touch-action: pan-y;
  user-select: none;
}

.view-home.is-dragging,
.view-home:active {
  cursor: grabbing;
}

.view-home:focus-visible {
  outline: 4px solid rgba(47,111,174,0.34);
  outline-offset: 0.45rem;
  border-radius: 28px;
}

.cylinder-wrap {
  position: relative;
  width: clamp(390px, 48vw, 650px);
  height: clamp(234px, 28.6vw, 385px);
  transform-style: preserve-3d;
  will-change: transform;
}

.cylinder-item {
  position: absolute;
  inset: 0;
  display: block;
  overflow: hidden;
  border: 1px solid rgba(36,49,70,0.16);
  border-radius: clamp(16px, 2.2vw, 26px);
  background: #fff;
  box-shadow: 0 22px 44px rgba(31,42,58,0.22), inset 0 1px 0 rgba(255,255,255,0.42);
  color: #fff;
  transform: rotateY(var(--cylinder-angle)) translateZ(420px);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  opacity: 0.58;
  transition: opacity 220ms ease, box-shadow 220ms ease;
}

.cylinder-item::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(10,16,24,0.16), rgba(10,16,24,0.22));
  transition: opacity 220ms ease, background 220ms ease;
}

.cylinder-item.is-active,
.cylinder-item--finished:hover,
.cylinder-item--finished:focus-visible {
  z-index: 20;
  opacity: 1;
  box-shadow: 0 26px 54px rgba(31,42,58,0.30), 0 0 0 1px rgba(255,255,255,0.30) inset;
}

.cylinder-item.is-active::before,
.cylinder-item--finished:hover::before,
.cylinder-item--finished:focus-visible::before {
  opacity: 0;
}

.cylinder-item--in-progress,
.cylinder-item--in-progress.is-active {
  opacity: 0.34;
}

.cylinder-item--in-progress::before,
.cylinder-item--in-progress.is-active::before {
  background: linear-gradient(180deg, rgba(226,231,238,0.58), rgba(8,13,22,0.24));
}

.cylinder-item:focus-visible {
  outline: 4px solid rgba(47,111,174,0.42);
  outline-offset: 6px;
}

.cylinder-item picture,
.cylinder-item img {
  width: 100%;
  height: 100%;
  display: block;
}

.cylinder-item img {
  object-fit: cover;
  object-position: top center;
  background: #fff;
  pointer-events: none;
}

.cylinder-item__shade {
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, transparent 45%, rgba(8,13,22,0.08) 100%);
  pointer-events: none;
}

.cylinder-item__meta {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  display: grid;
  gap: 0.4rem;
  padding: 0.72rem 0.78rem;
  border-radius: 16px;
  background: rgba(8,13,22,0.64);
  text-shadow: 0 2px 18px rgba(0,0,0,0.58);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.cylinder-item__meta strong {
  font-size: clamp(1.15rem, 2.2vw, 1.7rem);
  line-height: 1;
  letter-spacing: -0.04em;
}

.cylinder-item__meta span {
  color: rgba(255,255,255,0.86);
  font-size: clamp(0.78rem, 1.2vw, 0.92rem);
  line-height: 1.35;
}

.cylinder-open-affordance,
.cylinder-status {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0.92);
  opacity: 0;
  border-radius: 999px;
  padding: 0.7rem 0.95rem;
  background: rgba(255,255,255,0.90);
  color: #101822;
  font-weight: 900;
  z-index: 3;
  box-shadow: 0 14px 28px rgba(0,0,0,0.20);
  transition: opacity 180ms ease, transform 180ms ease;
}

.cylinder-item--finished.is-active.is-preview-ready:hover .cylinder-open-affordance,
.cylinder-item--finished.is-active.is-preview-ready:focus-visible .cylinder-open-affordance {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.cylinder-status,
.cylinder-item--in-progress.is-active .cylinder-status {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

@media (max-width: 720px) {
  .hero--trsnparent_wheel {
    padding-top: 4rem;
  }

  .carousel-drag-hint {
    display: none;
  }

  .view-home {
    min-height: 460px;
    overflow: visible;
    touch-action: pan-y;
  }

  .cylinder-wrap {
    width: clamp(174px, 50vw, 198px);
    height: auto;
    aspect-ratio: 390 / 844;
  }

  .cylinder-item img {
    object-fit: contain;
    transform: translateZ(0);
  }

  .cylinder-item:not(.is-active) {
    opacity: 0.3;
  }

  .cylinder-item:not(.is-active)::before {
    background: linear-gradient(180deg, rgba(230,235,242,0.64), rgba(8,13,22,0.34));
  }

  .cylinder-open-affordance,
  .cylinder-status {
    left: 50%;
    top: 50%;
    min-width: max-content;
    max-width: 78%;
    padding: 0.64rem 0.9rem;
    border: 1px solid rgba(255,255,255,0.72);
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(244,248,252,0.91));
    color: rgba(16,24,34,0.92);
    font-size: 0.78rem;
    line-height: 1;
    font-weight: 850;
    letter-spacing: -0.015em;
    text-align: center;
    white-space: nowrap;
    box-shadow: 0 12px 28px rgba(31,42,58,0.20), 0 0 0 5px rgba(255,255,255,0.18);
    transform: translate3d(-50%, -50%, 0) scale(0.94);
  }

  .cylinder-item:not(.is-active) .cylinder-open-affordance,
  .cylinder-item:not(.is-active) .cylinder-status {
    opacity: 0;
    transform: translate3d(-50%, -50%, 0) scale(0.9);
  }

  .cylinder-item--finished.is-active.is-preview-ready .cylinder-open-affordance,
  .cylinder-item--in-progress.is-active .cylinder-status {
    opacity: 1;
    transform: translate3d(-50%, -50%, 0) scale(1);
  }

  .carousel-centre-label {
    margin-top: 0.85rem;
  }

  .cylinder-item__meta span {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }

  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }

  .cylinder-wrap,
  .cylinder-item {
    will-change: auto;
  }
}

.service-faq {
  margin-top: clamp(2.5rem, 6vw, 5rem);
}

.service-faq-list,
.service-faq-list--dropdown {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.72rem;
  margin-top: 1.15rem;
}

details.service-faq-item {
  overflow: clip;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 34px rgba(64, 78, 101, 0.09);
  transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

details.service-faq-item[open] {
  border-color: rgba(47, 111, 174, 0.28);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 18px 42px rgba(64, 78, 101, 0.12);
}

.service-faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  min-height: 4.35rem;
  padding: 0.95rem 1rem;
  cursor: pointer;
  list-style: none;
  font-weight: 850;
  letter-spacing: -0.035em;
  line-height: 1.12;
  color: var(--text);
}

.service-faq-item summary::-webkit-details-marker {
  display: none;
}

.service-faq-item summary:focus-visible {
  outline: 3px solid rgba(185,216,255,0.62);
  outline-offset: -4px;
  border-radius: 18px;
}

.service-faq-toggle {
  flex: 0 0 auto;
  display: inline-grid;
  place-items: center;
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 999px;
  background: rgba(47, 111, 174, 0.10);
  color: var(--accent-strong);
  font-size: 0;
  line-height: 0;
  position: relative;
  transition: background 160ms ease;
}

.service-faq-toggle::before,
.service-faq-toggle::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  width: 0.76rem;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform: translate(-50%, -50%);
  transition: transform 160ms ease;
}

.service-faq-toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

details.service-faq-item[open] .service-faq-toggle {
  background: rgba(47, 111, 174, 0.17);
}

details.service-faq-item[open] .service-faq-toggle::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

details.service-faq-item[open] .service-faq-toggle::after {
  transform: translate(-50%, -50%) rotate(135deg);
}

.service-faq-answer {
  padding: 0 1rem 1rem;
  margin-top: -0.1rem;
}

.service-faq-answer p,
.service-faq-item p {
  margin: 0;
  font-size: 0.97rem;
  line-height: 1.58;
}

@media (max-width: 760px) {
  .service-faq-list,
  .service-faq-list--dropdown {
    grid-template-columns: 1fr;
  }
}
