html.osf-lock,
html.osf-lock body {
  overflow: hidden;
}

.osf-float {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 80;
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  border: 1px solid rgba(255, 255, 255, .46);
  border-radius: 50%;
  background: #25191f;
  color: #fffaf6;
  box-shadow: 0 18px 42px rgba(37, 25, 31, .28);
}

.osf-float:not(:hover):not(:focus-visible) {
  animation: osfFloatNudge 7s ease-in-out 2.2s infinite;
}

.osf-float svg {
  flex-shrink: 0;
}

@keyframes osfFloatNudge {
  0%, 82%, 100% { transform: translateY(0); box-shadow: 0 18px 42px rgba(37, 25, 31, .28); }
  86% { transform: translateY(-4px); box-shadow: 0 24px 52px rgba(37, 25, 31, .36); }
  90% { transform: translateY(0); }
  94% { transform: translateY(-2px); }
}

.osf-game {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: clamp(18px, 4vw, 52px);
  color: #fff8f2;
  opacity: 0;
  transform: scale(1.01);
  transition: opacity .22s ease, transform .22s ease;
}

.osf-game.is-shuffling {
  padding: 0;
}

.osf-game[hidden] {
  display: none !important;
}

.osf-game.is-open {
  opacity: 1;
  transform: scale(1);
}

.osf-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 22%, rgba(255, 222, 164, .18), transparent 24%),
    radial-gradient(circle at 82% 72%, rgba(225, 64, 90, .18), transparent 26%),
    linear-gradient(145deg, #160f18 0%, #22141e 46%, #120f18 100%);
  overflow: hidden;
}

.osf-bg::before,
.osf-bg::after {
  content: "";
  position: absolute;
  inset: -20%;
  background-image:
    radial-gradient(circle, rgba(255, 255, 255, .42) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(255, 207, 140, .28) 0 1px, transparent 1.7px);
  background-size: 120px 120px, 190px 190px;
  animation: osfDrift 24s linear infinite;
}

.osf-bg::after {
  opacity: .45;
  filter: blur(1px);
  animation-duration: 38s;
  animation-direction: reverse;
}

.theme-soft_space .osf-bg {
  background:
    radial-gradient(circle at 20% 18%, rgba(133, 198, 218, .18), transparent 28%),
    radial-gradient(circle at 76% 72%, rgba(232, 177, 204, .16), transparent 32%),
    linear-gradient(145deg, #0f1720, #1e1b2a 58%, #11141d);
}

.theme-noir_ritual .osf-bg {
  background:
    radial-gradient(circle at 72% 34%, rgba(196, 154, 90, .16), transparent 26%),
    linear-gradient(145deg, #100d0c, #211716 60%, #120d0f);
}

.theme-romance_lux .osf-bg {
  background:
    radial-gradient(circle at 22% 24%, rgba(212, 163, 115, .22), transparent 30%),
    radial-gradient(circle at 80% 74%, rgba(110, 36, 56, .34), transparent 34%),
    linear-gradient(150deg, #14070c 0%, #2a0f18 48%, #14070c 100%);
}

.theme-romance_lux .osf-bg::before,
.theme-romance_lux .osf-bg::after {
  background-image:
    radial-gradient(circle, rgba(212, 163, 115, .5) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(233, 201, 169, .3) 0 1px, transparent 1.7px);
}

.theme-romance_lux .osf-eyebrow,
.theme-romance_lux .osf-last-card p { color: #e3b98a; }

.theme-romance_lux .osf-primary {
  border-color: #d4a373;
  background: linear-gradient(135deg, #e9c9a9, #d4a373);
  color: #2a0f18;
}

/* cinematic vignette over the whole stage */
.osf-bg::after,
.osf-vignette { pointer-events: none; }

.osf-game::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  background: radial-gradient(ellipse at 50% 46%, transparent 46%, rgba(8, 5, 9, .68) 100%);
  transition: opacity .8s ease;
}

.osf-game.is-shuffling::after {
  opacity: 1;
}

@keyframes osfDrift {
  to { transform: translate3d(90px, -80px, 0); }
}

.osf-close {
  position: absolute;
  top: 22px;
  right: 22px;
  z-index: 2;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 255, 255, .28);
  border-radius: 50%;
  background: rgba(255, 255, 255, .08);
  color: #fff;
  font-size: 28px;
  line-height: 1;
}

.osf-stage {
  position: relative;
  z-index: 1;
  width: min(1120px, 100%);
  min-height: min(680px, calc(100vh - 80px));
  display: grid;
  grid-template-columns: minmax(260px, .82fr) minmax(300px, 1fr);
  align-items: center;
  gap: clamp(22px, 5vw, 80px);
}

.is-shuffling .osf-stage {
  width: 100vw;
  min-height: 100vh;
  grid-template-columns: 1fr;
  justify-items: center;
  overflow: visible;
}

.is-shuffling .osf-copy {
  opacity: 0;
  transform: translateY(-18px) scale(.96);
  pointer-events: none;
}

.osf-copy h2 {
  max-width: 9ch;
  margin: 0;
  font-family: var(--f-serif, Georgia, serif);
  font-size: clamp(50px, 8vw, 104px);
  font-weight: 400;
  line-height: .88;
}

.osf-copy p {
  max-width: 440px;
  color: rgba(255, 248, 242, .76);
  font-size: 16px;
  line-height: 1.7;
}

.osf-intro-message {
  width: fit-content;
  padding: 12px 14px;
  border: 1px solid rgba(255, 212, 154, .2);
  border-radius: 8px;
  background: rgba(255, 255, 255, .07);
}

.osf-copy {
  transition: opacity .28s ease, transform .28s ease;
}

.osf-eyebrow {
  margin: 0 0 14px;
  color: #ffd49a;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .16em;
}

.osf-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 24px 0 8px;
}

.osf-last-card {
  width: min(390px, 100%);
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  margin-top: 20px;
  padding: 10px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 10px;
  background: rgba(255, 255, 255, .075);
  backdrop-filter: blur(12px);
  text-align: left;
  cursor: pointer;
  transition: transform .3s cubic-bezier(.22, 1, .36, 1), border-color .3s ease, background .3s ease, box-shadow .3s ease;
}

.osf-last-card:hover,
.osf-last-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 212, 154, .55);
  background: rgba(255, 255, 255, .12);
  box-shadow: 0 18px 40px rgba(0, 0, 0, .3);
  outline: none;
}

.osf-last-card:hover .osf-last-media,
.osf-last-card:focus-visible .osf-last-media {
  transform: scale(1.04) rotate(-2deg);
}

.osf-last-media {
  transition: transform .35s cubic-bezier(.22, 1, .36, 1);
}

.osf-last-expand {
  align-self: center;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, .26);
  color: #ffd49a;
  font-size: 16px;
  line-height: 1;
}

.osf-last-media {
  aspect-ratio: 3 / 4;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 6px;
  background: linear-gradient(145deg, #3a2430, #d64862);
  box-shadow: 0 12px 26px rgba(0, 0, 0, .22);
}

.osf-last-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.osf-last-media span {
  font-family: var(--f-serif, Georgia, serif);
  font-size: 32px;
  font-style: italic;
}

.osf-last-card p {
  margin: 0 0 4px;
  color: #ffd49a;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  line-height: 1.2;
}

.osf-last-card strong {
  display: block;
  color: #fff8f2;
  font-family: var(--f-serif, Georgia, serif);
  font-size: 20px;
  font-weight: 400;
  line-height: 1.05;
}

.osf-last-card small {
  display: block;
  margin-top: 4px;
  color: rgba(255, 248, 242, .62);
  font-size: 12px;
}

.osf-primary,
.osf-link {
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  font: 700 13px/1 var(--f-sans, system-ui, sans-serif);
}

.osf-primary {
  border: 1px solid #ffd49a;
  background: #ffd49a;
  color: #23161d;
}

.osf-link {
  border: 1px solid rgba(255, 255, 255, .28);
  background: rgba(255, 255, 255, .08);
  color: #fff8f2;
}

.osf-deck {
  position: relative;
  min-height: 460px;
  perspective: 1200px;
  transform-style: preserve-3d;
  cursor: pointer;
  touch-action: manipulation;
  transition: transform .42s cubic-bezier(.22, 1, .36, 1), min-height .42s ease, opacity .7s ease;
  overflow: visible;
}

.osf-deck canvas {
  width: 100%;
  height: 100%;
  min-height: 460px;
  display: block;
  filter: drop-shadow(0 28px 44px rgba(0, 0, 0, .24));
}

.osf-deck.is-three {
  min-height: 520px;
}

.osf-game.is-mode-home .osf-stage {
  grid-template-columns: minmax(240px, .62fr) minmax(320px, 1.18fr);
}

.osf-game.is-mode-home .osf-deck {
  min-height: 0;
  cursor: default;
}

.osf-mode-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: clamp(12px, 2vw, 20px);
}

.osf-mode-card {
  position: relative;
  min-height: 330px;
  display: grid;
  align-content: end;
  overflow: hidden;
  padding: 16px;
  border: 1px solid rgba(255, 212, 154, .24);
  border-radius: 10px;
  background: rgba(255, 255, 255, .08);
  color: #fff8f2;
  text-align: left;
  box-shadow: 0 28px 70px rgba(0, 0, 0, .3);
  cursor: pointer;
  transform: translateY(0);
  transition: transform .38s cubic-bezier(.22, 1, .36, 1), border-color .32s ease, box-shadow .32s ease;
}

.osf-mode-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10, 6, 10, 0) 22%, rgba(10, 6, 10, .78) 100%);
  pointer-events: none;
}

.osf-mode-card:hover,
.osf-mode-card:focus-visible {
  transform: translateY(-6px) scale(1.01);
  border-color: rgba(255, 212, 154, .58);
  box-shadow: 0 36px 86px rgba(0, 0, 0, .42);
  outline: none;
}

.osf-mode-image {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, #2b1b27, #d84862);
  font-family: var(--f-serif, Georgia, serif);
  font-size: 78px;
  font-style: italic;
  transition: transform .6s cubic-bezier(.22, 1, .36, 1), filter .6s ease;
}

.osf-mode-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.osf-mode-card:hover .osf-mode-image,
.osf-mode-card:focus-visible .osf-mode-image {
  transform: scale(1.06);
  filter: saturate(1.08);
}

.osf-mode-name,
.osf-mode-mark,
.osf-mode-teaser {
  position: relative;
  z-index: 1;
}

.osf-mode-name {
  display: block;
  max-width: 10ch;
  font-family: var(--f-serif, Georgia, serif);
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 400;
  line-height: .96;
}

.osf-mode-mark {
  width: fit-content;
  margin-top: 12px;
  padding: 8px 11px;
  border: 1px solid rgba(255, 212, 154, .42);
  border-radius: 999px;
  color: #ffd49a;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.osf-mode-teaser {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  max-width: 100%;
  margin-top: 8px;
  padding: 5px 9px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 999px;
  background: rgba(0, 0, 0, .32);
  backdrop-filter: blur(8px);
  color: rgba(255, 248, 242, .82);
  font-size: 11px;
  font-style: italic;
  font-family: var(--f-serif, Georgia, serif);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.osf-mode-teaser::before {
  content: "♦";
  flex-shrink: 0;
  font-size: 7px;
  font-style: normal;
  color: #ffd49a;
  opacity: .9;
}

.is-shuffling .osf-deck {
  width: min(1180px, 100vw);
  min-height: min(860px, 88vh);
  transform: scale(1.04);
  z-index: 3;
}

.is-shuffling .osf-deck canvas {
  min-height: min(860px, 88vh);
}

.osf-card {
  position: absolute;
  left: 50%;
  top: 50%;
  width: clamp(118px, 12vw, 164px);
  aspect-ratio: 3 / 4.35;
  border: 1px solid rgba(255, 255, 255, .48);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.2), transparent 34%),
    radial-gradient(circle at 50% 36%, rgba(255, 212, 154, .4), transparent 22%),
    linear-gradient(145deg, #2d1c26, #c7435d);
  background-size: cover;
  background-position: center;
  box-shadow: 0 20px 44px rgba(0, 0, 0, .28), inset 0 0 0 7px rgba(255, 255, 255, .11);
  transform: translate3d(calc(-50% + var(--x)), -50%, calc(var(--i) * 1px)) rotate(var(--r)) rotateX(6deg);
  transition: transform .42s cubic-bezier(.22, 1, .36, 1), box-shadow .42s ease;
}

.osf-card::after {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid rgba(255, 255, 255, .42);
  border-radius: 7px;
}

.osf-card:hover {
  box-shadow: 0 28px 60px rgba(0, 0, 0, .34), inset 0 0 0 7px rgba(255, 255, 255, .13);
}

.is-shuffling .osf-card {
  animation: osfShuffle var(--osf-shuffle-ms, 2600ms) cubic-bezier(.55, 0, .18, 1) both;
  animation-delay: calc(var(--i) * 18ms);
}

@keyframes osfShuffle {
  0% { transform: translate3d(calc(-50% + var(--x)), -50%, calc(var(--i) * 1px)) rotate(var(--r)) rotateX(6deg); }
  30% { transform: translate3d(calc(-50% + 80px - var(--x)), -88%, 110px) rotate(28deg) rotateY(42deg); }
  62% { transform: translate3d(calc(-50% - 95px + var(--x)), -20%, 150px) rotate(-32deg) rotateY(-52deg); }
  100% { transform: translate3d(calc(-50% + var(--x)), -50%, calc(var(--i) * 1px)) rotate(var(--r)) rotateX(6deg); }
}

.osf-mode-badge {
  position: absolute;
  top: 22px;
  left: 22px;
  z-index: 2;
  padding: 6px 14px;
  border: 1px solid rgba(255, 255, 255, .2);
  border-radius: 999px;
  background: rgba(0, 0, 0, .32);
  backdrop-filter: blur(10px);
  color: #ffd49a;
  font: 700 10px/1 var(--f-sans, system-ui, sans-serif);
  text-transform: uppercase;
  letter-spacing: .12em;
  pointer-events: none;
}

.osf-reveal-card.no-image {
  grid-template-columns: 1fr;
}

.osf-reveal-card.no-image .osf-reveal-copy,
.osf-reveal-card.no-image .osf-result-actions {
  grid-column: 1 / -1;
}

.osf-link-back {
  font-size: 12px;
  opacity: .72;
}

.osf-result {
  position: absolute;
  inset: 50% auto auto 50%;
  width: min(980px, 94vw);
  transform: translate(-50%, -50%);
  z-index: 4;
}

.osf-reveal-card {
  display: grid;
  grid-template-columns: minmax(280px, .82fr) minmax(260px, .9fr);
  gap: clamp(18px, 4vw, 42px);
  align-items: center;
  padding: clamp(14px, 2.6vw, 28px);
  background: linear-gradient(160deg, rgba(30, 17, 23, .86), rgba(15, 9, 13, .92));
  border: 1px solid rgba(255, 212, 154, .26);
  border-radius: 14px;
  backdrop-filter: blur(14px);
  box-shadow: 0 38px 90px rgba(0, 0, 0, .5), inset 0 1px 0 rgba(255, 255, 255, .08);
  animation: osfRevealIn .8s cubic-bezier(.2, 1, .22, 1) both;
}

.theme-romance_lux .osf-reveal-card {
  background: linear-gradient(160deg, rgba(42, 15, 24, .88), rgba(18, 7, 11, .94));
  border-color: rgba(212, 163, 115, .34);
}

@keyframes osfRevealIn {
  0% {
    opacity: 0;
    transform: translateY(18px) scale(.94) rotateX(6deg);
    filter: blur(10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1) rotateX(0);
    filter: blur(0);
  }
}

.osf-reveal-media {
  width: min(44vh, 420px);
  max-width: 100%;
  aspect-ratio: 3 / 4;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: linear-gradient(145deg, #3a2430, #d64862);
  border-radius: 8px;
}

.osf-reveal-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.osf-reveal-media span {
  font-family: var(--f-serif, Georgia, serif);
  font-size: 84px;
  font-style: italic;
}

.osf-reveal-copy h3 {
  margin: 0;
  font-family: var(--f-serif, Georgia, serif);
  font-size: var(--osf-reveal-title, clamp(52px, 6vw, 88px));
  font-weight: 400;
  line-height: .92;
}

.osf-reveal-copy p:not(.osf-eyebrow) {
  font-size: var(--osf-reveal-body, clamp(16px, 1.5vw, 20px));
  color: rgba(255, 248, 242, .78);
  line-height: 1.7;
}

.osf-reveal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 12px;
}

.osf-reveal-meta span {
  padding: 7px 10px;
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 999px;
  background: rgba(255, 255, 255, .08);
  color: #ffd49a;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.osf-illustration-note {
  max-height: 110px;
  overflow: auto;
  color: rgba(255, 248, 242, .58) !important;
  font-size: 13px;
}

.osf-result-actions {
  grid-column: 1 / 2;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-top: -4px;
}

.has-result .osf-deck {
  opacity: 0;
  transform: scale(1.02);
  pointer-events: none;
}

.woocommerce nav.woocommerce-pagination,
.woocommerce-pagination {
  margin: 34px 0 12px;
}

.woocommerce nav.woocommerce-pagination ul,
.woocommerce-pagination ul,
.woocommerce-pagination .page-numbers {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  border: 0;
}

.woocommerce nav.woocommerce-pagination ul li,
.woocommerce-pagination ul li {
  border: 0;
  margin: 0;
  overflow: visible;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
.woocommerce-pagination a.page-numbers,
.woocommerce-pagination span.page-numbers {
  min-width: 38px;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 13px;
  border: 1px solid rgba(37, 25, 31, .16);
  border-radius: 999px;
  background: #fffaf6;
  color: #25191f;
  font: 700 13px/1 var(--f-sans, system-ui, sans-serif);
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(37, 25, 31, .07);
  transition: transform .2s ease, border-color .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
}

.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li a:focus-visible,
.woocommerce-pagination a.page-numbers:hover,
.woocommerce-pagination a.page-numbers:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(216, 63, 84, .38);
  background: #fff2ea;
  color: #d83f54;
  box-shadow: 0 14px 30px rgba(37, 25, 31, .11);
  outline: none;
}

.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce-pagination span.page-numbers.current {
  border-color: #ffd49a;
  background: #25191f;
  color: #fffaf6;
  box-shadow: 0 16px 34px rgba(37, 25, 31, .18);
}

@media (max-width: 820px) {
  .osf-float {
    right: max(14px, env(safe-area-inset-right)) !important;
    bottom: max(72px, calc(env(safe-area-inset-bottom) + 58px)) !important;
    width: 52px !important;
    height: 52px !important;
  }
  .osf-game {
    align-items: center;
    padding: 14px 14px max(14px, env(safe-area-inset-bottom));
    height: 100vh;
    height: 100dvh;
    overflow: hidden;
  }
  .osf-close {
    top: max(10px, env(safe-area-inset-top));
    right: 12px;
    width: 40px;
    height: 40px;
  }
  .osf-mode-badge {
    top: max(10px, env(safe-area-inset-top));
    left: 12px;
    font-size: 9px;
    padding: 5px 10px;
  }
  .osf-stage {
    grid-template-columns: 1fr;
    min-height: 0;
    height: 100%;
    gap: 8px;
    align-content: center;
  }
  .osf-game.is-mode-home .osf-stage {
    grid-template-columns: 1fr;
    overflow: auto;
    align-content: start;
    padding-top: 56px;
  }
  .osf-mode-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .osf-mode-card {
    min-height: 172px;
    padding: 10px 12px;
  }
  .osf-mode-name {
    font-size: 22px;
  }
  .osf-mode-mark {
    padding: 6px 9px;
    font-size: 10px;
    margin-top: 8px;
  }
  .osf-mode-teaser {
    font-size: 11px;
  }
  .osf-copy h2 {
    max-width: 12ch;
    font-size: clamp(42px, 14vw, 58px);
  }
  .osf-copy p {
    font-size: 14px;
    line-height: 1.55;
  }
  .osf-actions {
    margin-top: 16px;
  }
  .osf-last-card {
    grid-template-columns: 54px minmax(0, 1fr);
    margin-top: 14px;
  }
  .osf-last-card strong {
    font-size: 18px;
  }
  .osf-deck {
    min-height: min(48vh, 380px);
  }
  .osf-deck canvas {
    min-height: min(48vh, 380px);
  }
  .is-shuffling .osf-deck,
  .is-shuffling .osf-deck canvas {
    width: 100vw;
    min-height: 72vh;
  }
  .osf-result {
    position: absolute;
    top: max(58px, env(safe-area-inset-top));
    right: 10px;
    bottom: max(10px, env(safe-area-inset-bottom));
    left: 10px;
    width: auto;
    max-height: none;
    transform: none;
  }
  .osf-reveal-card {
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr) auto;
    height: 100%;
    max-height: none;
    min-height: 0;
    gap: 8px;
    padding: 10px;
    box-sizing: border-box;
  }
  .osf-reveal-copy {
    min-height: 0;
    overflow: auto;
    padding-bottom: 4px;
  }
  .osf-result-actions {
    grid-column: 1 / -1;
    margin-top: 0;
    align-self: end;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(78px, 1fr));
    gap: 6px;
    padding-top: 6px;
  }
  .osf-reveal-media {
    width: min(42vw, 168px);
    max-height: 27dvh;
    aspect-ratio: 3 / 4;
    justify-self: center;
  }
  .osf-reveal-copy h3 {
    font-size: clamp(28px, 8vw, 42px);
  }
  .osf-reveal-copy p:not(.osf-eyebrow) {
    font-size: 14px;
    line-height: 1.5;
  }
  .osf-result-actions .osf-primary,
  .osf-result-actions .osf-link {
    width: 100%;
    min-width: 0;
    white-space: normal;
  }
}

@media (max-width: 420px) {
  .osf-mode-grid {
    grid-template-columns: 1fr 1fr;
  }
  .osf-mode-card {
    min-height: 150px;
  }
  .osf-reveal-card {
    padding: 12px;
  }
  .osf-reveal-media {
    width: min(50vw, 178px);
  }
  .osf-guide {
    max-height: 80px;
    overflow: auto;
  }
}

@media (max-width: 820px) {
  .osf-primary,
  .osf-link {
    min-height: 42px;
    padding: 0 12px;
    font-size: 12px;
    line-height: 1.12;
  }
  .osf-result-actions {
    position: static;
    background: none;
    padding: 6px 0 0;
  }
  .is-shuffling .osf-deck,
  .is-shuffling .osf-deck canvas {
    min-height: 80vh;
  }
  .osf-last-expand {
    width: 34px;
    height: 34px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .osf-bg::before,
  .osf-bg::after,
  .osf-float {
    animation: none;
  }
  .osf-reveal-card {
    animation-duration: .2s;
  }
  .osf-game.is-shuffling::after {
    transition: none;
  }
}
