.ybm-page {
  --ybm-orange: #ff9b21;
  --ybm-yellow: #ffd36a;
  --ybm-mud: #8b4b26;
  --ybm-hot: #ff4e7a;
  --ybm-card: rgba(24, 13, 23, 0.9);
  --ybm-card-2: rgba(37, 19, 25, 0.9);
  min-height: 100vh;
  background:
    radial-gradient(circle at 14% 8%, rgba(255, 155, 33, 0.19), transparent 30%),
    radial-gradient(circle at 90% 12%, rgba(255, 78, 122, 0.14), transparent 28%),
    radial-gradient(circle at 50% 100%, rgba(139, 75, 38, 0.23), transparent 40%),
    var(--bg);
}

.ybm-page main,
.ybm-nav {
  position: relative;
  z-index: 3;
}

.ybm-mud {
  position: fixed;
  z-index: 1;
  pointer-events: none;
  border-radius: 999px;
  filter: blur(1px);
  opacity: 0.4;
  background: radial-gradient(circle, rgba(255, 155, 33, 0.7), rgba(139, 75, 38, 0.16) 58%, transparent 70%);
}

.ybm-mud-a {
  width: 180px;
  height: 180px;
  left: -70px;
  top: 22%;
}

.ybm-mud-b {
  width: 260px;
  height: 260px;
  right: -110px;
  bottom: 12%;
  background: radial-gradient(circle, rgba(255, 78, 122, 0.35), rgba(255, 155, 33, 0.13) 54%, transparent 70%);
}

.ybm-nav {
  border-bottom: 1px solid rgba(255,255,255,0.1);
  background: rgba(8, 6, 17, 0.76);
}

.ybm-nav-inner { min-height: 74px; }

.ybm-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.ybm-brand span span { color: var(--fg-dim); }

.ybm-brand-mark {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: 0 0 28px rgba(255, 155, 33, 0.18);
}

.ybm-brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ybm-nav-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.ybm-nav-link {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  color: var(--fg-muted);
  font-family: var(--f-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0 14px;
}

.ybm-lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
}

.ybm-lang {
  min-height: 30px;
  min-width: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: var(--fg-dim);
  font-family: var(--f-mono);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  transition: color .2s var(--ease-out), background .2s var(--ease-out), box-shadow .2s var(--ease-out);
}

.ybm-lang.active {
  color: var(--accent-ink);
  background: linear-gradient(135deg, var(--ybm-orange), var(--ybm-yellow));
  box-shadow: 0 0 20px rgba(255, 155, 33, 0.15);
}

.ybm-hero {
  width: min(100%, var(--max));
  margin: 0 auto;
  padding: clamp(26px, 5vw, 60px) var(--pad) clamp(42px, 7vw, 84px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  overflow: hidden;
}

.ybm-hero-copy {
  display: grid;
  gap: 16px;
  align-content: center;
}

.ybm-kicker,
.ybm-section-label {
  width: fit-content;
  color: var(--ybm-yellow);
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.ybm-kicker {
  padding: 8px 12px;
  border: 1px solid rgba(255, 155, 33, 0.28);
  border-radius: 999px;
  background: rgba(255, 155, 33, 0.08);
}

.ybm-logo-lockup {
  width: min(100%, 620px);
}

.ybm-logo-lockup img {
  width: 100%;
  display: block;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 24px 70px -44px rgba(0,0,0,.96), 0 0 38px rgba(255, 155, 33, 0.12);
}

.ybm-hero-line {
  max-width: 14ch;
  color: var(--fg);
  font-size: clamp(30px, 7vw, 68px);
  font-weight: 800;
  letter-spacing: -0.055em;
  line-height: 0.92;
}

.ybm-hero-text {
  max-width: 58ch;
  color: var(--fg-muted);
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.5;
}

.ybm-store-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 4px;
}

.ybm-store {
  min-height: 64px;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 13px 20px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.05);
  box-shadow: 0 22px 60px -42px rgba(0,0,0,.96);
  transition: transform .22s var(--ease-out), border-color .22s var(--ease-out), box-shadow .22s var(--ease-out);
}

.ybm-store:hover {
  transform: translateY(-2px) rotate(-0.3deg);
  border-color: rgba(255,255,255,0.3);
  box-shadow: 0 26px 64px -38px rgba(0,0,0,.92), 0 0 24px rgba(255, 155, 33, 0.12);
}

.ybm-store-copy {
  display: grid;
  gap: 1px;
}

.ybm-store-copy span {
  color: rgba(245, 243, 255, 0.72);
  font-family: var(--f-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ybm-store-copy strong {
  color: var(--fg);
  font-size: 22px;
  line-height: 1;
  letter-spacing: -0.035em;
}

.ybm-store-primary {
  color: #1b0e05;
  border-color: rgba(255, 211, 106, 0.55);
  background: linear-gradient(135deg, var(--ybm-orange), var(--ybm-yellow));
}

.ybm-store-primary .ybm-store-copy span,
.ybm-store-primary .ybm-store-copy strong {
  color: #1b0e05;
}

.ybm-store-icon {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  border-radius: 15px;
  color: #1b0e05;
  background: linear-gradient(135deg, var(--ybm-orange), var(--ybm-yellow));
  box-shadow: 0 0 24px rgba(255, 155, 33, 0.2);
}

.ybm-store-primary .ybm-store-icon {
  background: rgba(27, 14, 5, 0.12);
  box-shadow: 0 0 0 1px rgba(27, 14, 5, 0.12) inset;
}

.ybm-store-icon svg {
  width: 23px;
  height: 23px;
  fill: currentColor;
}

.ybm-secondary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 2px;
}

.ybm-secondary-actions .btn {
  min-height: 48px;
  border-color: rgba(255, 155, 33, 0.22);
  background: rgba(255, 155, 33, 0.055);
}

.ybm-secondary-actions .btn:hover {
  border-color: rgba(255, 211, 106, 0.42);
  background: rgba(255, 155, 33, 0.09);
}

.ybm-phone-wrap {
  min-height: 440px;
  display: grid;
  place-items: center;
  position: relative;
}

.ybm-phone {
  width: min(74vw, 310px);
  aspect-ratio: 1242 / 2688;
  position: relative;
  overflow: hidden;
  padding: 10px;
  border-radius: 38px;
  border: 1px solid rgba(255,255,255,0.18);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02)),
    linear-gradient(180deg, #271317, #07050a);
  box-shadow:
    0 38px 90px -50px rgba(0,0,0,.98),
    0 0 52px rgba(255, 155, 33, 0.16);
  transform: rotate(1.5deg);
}

.ybm-phone img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 29px;
  background: #05050a;
}

.ybm-phone-notch {
  position: absolute;
  top: 10px;
  left: 31%;
  right: 31%;
  height: 17px;
  z-index: 2;
  border-radius: 0 0 12px 12px;
  background: rgba(7, 5, 10, 0.82);
}

.ybm-phone-shadow {
  position: absolute;
  z-index: -1;
  width: 58%;
  height: 48px;
  bottom: 28px;
  border-radius: 50%;
  background: rgba(0,0,0,0.5);
  filter: blur(16px);
}

.ybm-section,
.ybm-final {
  width: min(100%, var(--max));
  margin: 0 auto;
  padding: clamp(64px, 8vw, 112px) var(--pad) 0;
}

.ybm-section-head {
  display: grid;
  gap: 16px;
  margin-bottom: 22px;
}

.ybm-section h2,
.ybm-final h2 {
  max-width: 12ch;
  font-size: clamp(38px, 7vw, 86px);
  line-height: 0.92;
  letter-spacing: -0.055em;
}

.ybm-loop-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.ybm-loop-card,
.ybm-feature-grid article,
.ybm-note-card,
.ybm-trailer-card,
.ybm-final-card {
  border: 1px solid rgba(255,255,255,0.12);
  background:
    radial-gradient(circle at 18% 0%, rgba(255,155,33,0.12), transparent 32%),
    linear-gradient(180deg, var(--ybm-card), rgba(11, 8, 18, 0.92));
  box-shadow: 0 26px 70px -52px rgba(0,0,0,.98);
}

.ybm-loop-card {
  min-height: 188px;
  display: grid;
  align-content: space-between;
  gap: 16px;
  padding: 20px;
  border-radius: 24px;
}

.ybm-loop-card span {
  color: var(--ybm-yellow);
  font-family: var(--f-mono);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
}

.ybm-loop-card h3 {
  font-size: 26px;
  line-height: 0.98;
  letter-spacing: -0.04em;
}

.ybm-loop-card p,
.ybm-feature-grid p,
.ybm-note-card p {
  color: var(--fg-muted);
  line-height: 1.55;
}

.ybm-proof-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 34px;
}

.ybm-shot-stack {
  min-height: 380px;
  position: relative;
  display: grid;
  place-items: center;
}

.ybm-shot {
  width: min(48vw, 230px);
  aspect-ratio: 1242 / 2688;
  object-fit: cover;
  border-radius: 28px;
  border: 9px solid rgba(255,255,255,0.08);
  background: #05050a;
  box-shadow: 0 32px 80px -46px rgba(0,0,0,.96);
}

.ybm-shot-a {
  transform: translateX(-18%) rotate(-4deg);
}

.ybm-shot-b {
  position: absolute;
  transform: translateX(28%) translateY(28px) rotate(5deg);
}

.ybm-proof-copy {
  display: grid;
  gap: 18px;
}

.ybm-feature-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.ybm-feature-grid article {
  padding: 18px;
  border-radius: 20px;
}

.ybm-feature-grid strong {
  display: block;
  margin-bottom: 8px;
  color: var(--fg);
  font-size: 19px;
  line-height: 1.05;
  letter-spacing: -0.025em;
}

.ybm-feature-grid p {
  font-size: 14px;
}

.ybm-note-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.ybm-note-card,
.ybm-trailer-card {
  border-radius: 28px;
  padding: clamp(22px, 4vw, 34px);
}

.ybm-note-card {
  background:
    radial-gradient(circle at 86% 12%, rgba(255,78,122,0.16), transparent 34%),
    linear-gradient(180deg, var(--ybm-card-2), rgba(10, 8, 18, 0.92));
}

.ybm-note-card p {
  margin-top: 16px;
  max-width: 48ch;
  color: var(--fg);
  font-size: clamp(22px, 4vw, 40px);
  line-height: 1.02;
  letter-spacing: -0.045em;
}

.ybm-trailer-card {
  display: grid;
  align-content: space-between;
  gap: 22px;
  background:
    radial-gradient(circle at 88% 18%, rgba(255,155,33,0.18), transparent 34%),
    linear-gradient(180deg, rgba(21, 13, 27, 0.94), rgba(9, 7, 16, 0.92));
}

.ybm-trailer-card h2 {
  max-width: 10ch;
  font-size: clamp(32px, 4.2vw, 54px);
  line-height: 0.94;
  letter-spacing: -0.05em;
}

.ybm-trailer-link {
  min-height: 64px;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  border-radius: 22px;
  border: 1px solid rgba(255, 155, 33, 0.35);
  background: rgba(255, 155, 33, 0.08);
  color: var(--fg);
  font-weight: 800;
  letter-spacing: -0.02em;
  transition: transform .22s var(--ease-out), border-color .22s var(--ease-out), background .22s var(--ease-out);
}

.ybm-trailer-link:hover {
  transform: translateY(-2px);
  border-color: rgba(255, 211, 106, 0.65);
  background: rgba(255, 155, 33, 0.12);
}

.ybm-play-dot {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  color: #1b0e05;
  background: linear-gradient(135deg, var(--ybm-orange), var(--ybm-yellow));
  font-size: 15px;
}

.ybm-gallery-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}

.ybm-gallery-grid img {
  width: 100%;
  aspect-ratio: 1242 / 2688;
  display: block;
  object-fit: cover;
  border-radius: 26px;
  padding: 8px;
  border: 1px solid rgba(255,255,255,0.14);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.01)),
    linear-gradient(180deg, #1b1014, #07050a);
  box-shadow: 0 28px 72px -48px rgba(0,0,0,.96);
}

.ybm-gallery-grid img:nth-child(2),
.ybm-gallery-grid img:nth-child(4) {
  transform: translateY(24px);
}

.ybm-final {
  padding-bottom: clamp(54px, 8vw, 100px);
}

.ybm-final-card {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: 22px;
  padding: clamp(26px, 6vw, 56px);
  border-radius: 34px;
  text-align: left;
}

.ybm-final .ybm-section-label {
  opacity: 0.86;
}

.ybm-final h2 {
  font-size: clamp(34px, 5vw, 62px);
  line-height: 0.94;
  max-width: 12ch;
}

.ybm-final-copy {
  display: grid;
  align-content: start;
  gap: 18px;
}

.ybm-final-media img {
  width: min(100%, 500px);
  display: block;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 22px 62px -44px rgba(0,0,0,.96);
}

.ybm-final-actions {
  position: relative;
  z-index: 2;
  align-self: end;
}

.ybm-final-card::after {
  content: "";
  position: absolute;
  right: -80px;
  bottom: -110px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 155, 33, 0.28), transparent 70%);
  pointer-events: none;
}

.ybm-store-row-final {
  position: relative;
  z-index: 2;
}

@media (min-width: 560px) {
  .ybm-store-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (min-width: 900px) {
  .ybm-hero {
    min-height: calc(100vh - 74px);
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.72fr);
    align-items: center;
    gap: clamp(34px, 6vw, 84px);
  }

  .ybm-phone-wrap {
    min-height: 660px;
  }

  .ybm-phone {
    width: min(28vw, 360px);
    transform: rotate(2.2deg);
  }

  .ybm-loop-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .ybm-loop-card:nth-child(2),
  .ybm-loop-card:nth-child(4) {
    transform: translateY(26px);
  }

  .ybm-proof-section {
    grid-template-columns: 0.82fr 1fr;
    align-items: center;
  }

  .ybm-shot-stack {
    min-height: 660px;
  }

  .ybm-shot {
    width: min(20vw, 260px);
  }

  .ybm-note-section {
    grid-template-columns: 1.15fr 0.85fr;
    align-items: stretch;
  }

  .ybm-gallery-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
  }

  .ybm-final-card {
    grid-template-columns: 0.9fr 1fr;
    align-items: center;
    gap: clamp(28px, 5vw, 70px);
  }

  .ybm-final h2 {
    max-width: 11ch;
  }
}

@media (max-width: 700px) {
  .ybm-brand span:not(.ybm-brand-mark) {
    display: none;
  }

  .ybm-nav-link {
    font-size: 9px;
    padding: 0 11px;
  }

  .ybm-logo-lockup img {
    border-radius: 18px;
  }

  .ybm-phone-wrap {
    order: -1;
    min-height: 386px;
    margin-top: 6px;
  }

  .ybm-phone {
    width: min(62vw, 248px);
    border-radius: 32px;
  }

  .ybm-phone img {
    border-radius: 23px;
  }

  .ybm-loop-card {
    min-height: 152px;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .ybm-phone {
    animation: ybm-float 5.6s ease-in-out infinite;
  }

}

@keyframes ybm-float {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -10px; }
}
