/* ══════════════════════════════════════════
   情侣空间 · 照片墙 Photo Wall
   纯 CSS 还原 · 无参考图铺底
   ══════════════════════════════════════════ */

.miya-couple-app.is-photos .cp-view-space {
  visibility: hidden;
  pointer-events: none;
}

.cp-view-photos {
  --ph-wall: #c4c0b8;
  --ph-wall-deep: #b0aca4;
  --ph-ink: rgba(255, 255, 255, 0.92);
  --ph-ink-soft: rgba(255, 255, 255, 0.62);
  --ph-glass: rgba(255, 255, 255, 0.18);
  --ph-paper: #e8e0d4;
  --ph-paper-warm: #ebe3d6;
  position: absolute;
  inset: 0;
  z-index: 150;
  overflow: hidden;
  color: var(--ph-ink);
  font-family: 'Jost', 'Noto Sans SC', sans-serif;
  font-weight: 300;
  -webkit-tap-highlight-color: transparent;
}

.cp-view-photos[hidden] { display: none !important; }

.cp-ph-scene {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* ── 墙面 ── */
.cp-ph-wall {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.cp-ph-wall__base {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 90% 60% at 50% 0%, #d0ccc4 0%, var(--ph-wall) 45%, var(--ph-wall-deep) 100%);
}

.cp-ph-wall__light {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(118deg, rgba(255, 252, 245, 0.28) 0%, transparent 42%),
    linear-gradient(125deg, transparent 55%, rgba(255, 255, 255, 0.08) 72%, transparent 88%);
  opacity: 0.9;
}

.cp-ph-wall__shadow {
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(
      118deg,
      transparent,
      transparent 18px,
      rgba(90, 82, 72, 0.045) 18px,
      rgba(90, 82, 72, 0.045) 28px,
      transparent 28px,
      transparent 52px
    );
  opacity: 0.55;
}

.cp-ph-wall__grain {
  position: absolute;
  inset: 0;
  opacity: 0.35;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}

/* ── 顶部 ── */
.cp-ph-head {
  position: relative;
  z-index: 30;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: start;
  gap: 8px;
  padding: calc(env(safe-area-inset-top, 0px) + 12px) 16px 0 14px;
}

.cp-ph-back {
  width: 34px;
  height: 34px;
  margin-top: 2px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  -webkit-appearance: none;
  appearance: none;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.cp-ph-back svg { width: 18px; height: 18px; }
.cp-ph-back:active { background: rgba(255, 255, 255, 0.16); }

.cp-ph-head__main {
  position: relative;
  padding-top: 6px;
  min-width: 0;
}

.cp-ph-head__arc {
  position: absolute;
  top: -8px;
  left: -6px;
  width: 88px;
  height: 88px;
  pointer-events: none;
  opacity: 0.85;
}

.cp-ph-head__arc svg { width: 100%; height: 100%; }

.cp-ph-head__title {
  margin: 0;
  font-family: 'Playfair Display', 'Instrument Serif', Georgia, serif;
  font-size: clamp(22px, 6.2vw, 28px);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.96);
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.08);
}

.cp-ph-head__sub {
  margin: 5px 0 0;
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--ph-ink-soft);
}

.cp-ph-album {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 28px;
  padding: 7px 14px 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.92);
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 12px;
  font-style: italic;
  cursor: pointer;
  white-space: nowrap;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 0 18px rgba(255, 255, 255, 0.06);
  -webkit-appearance: none;
  appearance: none;
}

.cp-ph-album__icon { width: 14px; height: 14px; opacity: 0.85; }

.cp-ph-album__spark {
  font-size: 8px;
  opacity: 0.55;
  line-height: 1;
}

.cp-ph-album__spark--r { margin-left: -2px; }
.cp-ph-album:active { background: rgba(255, 255, 255, 0.2); }

/* ── 拼贴区 ── */
.cp-ph-collage {
  position: absolute;
  left: 0;
  right: 14%;
  top: calc(env(safe-area-inset-top, 0px) + 108px);
  bottom: calc(env(safe-area-inset-bottom, 0px) + 148px);
  z-index: 10;
}

.cp-ph-collage--live {
  right: 8%;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.cp-ph-collage--live::-webkit-scrollbar { display: none; }

.cp-ph-collage__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 12px;
  padding: 4px 8px 28px 6px;
}

.cp-ph-collage--live .cp-ph-item {
  position: relative;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  width: auto !important;
  transform: rotate(var(--ph-rot, 0deg));
}

.cp-ph-polaroid--live {
  padding: 5px 5px 0;
  height: auto;
}

.cp-ph-polaroid__btn {
  display: block;
  width: 100%;
  margin: 0;
  border: none;
  padding: 0;
  background: transparent;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

.cp-ph-polaroid__btn:active { opacity: 0.92; }

.cp-ph-polaroid__img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  object-fit: contain;
  object-position: center;
  background: linear-gradient(145deg, #e8e4dc, #d0ccc4);
}

.cp-ph-polaroid__meta {
  margin: 5px 2px 6px;
  font-size: 6.5px;
  line-height: 1.35;
  text-align: center;
  color: rgba(80, 70, 62, 0.55);
  letter-spacing: 0.02em;
}

.cp-ph-empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 24px 20px;
  pointer-events: none;
}

.cp-ph-empty[hidden] { display: none !important; }

.cp-ph-empty__title {
  margin: 0;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 18px;
  color: rgba(255, 255, 255, 0.88);
}

.cp-ph-empty__sub {
  margin: 10px 0 0;
  font-size: 11px;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.52);
}

.cp-ph-item {
  position: absolute;
  margin: 0;
}

/* 图钉 */
.cp-ph-pin {
  position: absolute;
  top: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #f0ebe3, #c8b8a8 55%, #a89888);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.4);
  z-index: 5;
}

/* 胶带 */
.cp-ph-tape {
  position: absolute;
  top: -4px;
  left: 50%;
  transform: translateX(-50%) rotate(-2deg);
  width: 34px;
  height: 12px;
  background: rgba(255, 255, 255, 0.42);
  border: 1px solid rgba(255, 255, 255, 0.25);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
  z-index: 5;
}

.cp-ph-tape--wide { width: 42px; }
.cp-ph-tape--stem {
  top: 0;
  left: 50%;
  width: 10px;
  height: 18px;
  transform: translateX(-50%);
}

/* 拍立得 */
.cp-ph-polaroid {
  background: #faf8f5;
  padding: 5px 5px 0;
  box-shadow: 0 8px 22px rgba(60, 50, 40, 0.14), 0 2px 6px rgba(60, 50, 40, 0.08);
}

.cp-ph-polaroid__img {
  position: relative;
  width: 100%;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.cp-ph-polaroid--cap {
  padding-bottom: 8px;
}

.cp-ph-polaroid__cap {
  margin: 6px 2px 0;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 6.5px;
  line-height: 1.35;
  text-align: center;
  color: rgba(80, 70, 62, 0.55);
  letter-spacing: 0.02em;
}

/* 照片内容 · CSS 渐变模拟 */
.cp-ph-img--plant {
  aspect-ratio: 3 / 4;
  background:
    linear-gradient(165deg, rgba(255, 248, 230, 0.5) 0%, transparent 40%),
    linear-gradient(180deg, #d8ccb8 0%, #b8a890 35%, #8a9478 70%, #6a7058 100%);
}

.cp-ph-img--plant::after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background:
    radial-gradient(ellipse 30% 50% at 65% 75%, rgba(90, 110, 70, 0.55), transparent),
    radial-gradient(ellipse 20% 30% at 30% 60%, rgba(120, 100, 70, 0.3), transparent);
}

.cp-ph-img--sea {
  aspect-ratio: 4 / 3;
  background:
    linear-gradient(180deg, #f0d8c0 0%, #e8b898 18%, #c89078 35%, #88a8b8 55%, #6890a8 75%, #486878 100%);
}

.cp-ph-img--tulip {
  aspect-ratio: 3 / 4.2;
  background:
    radial-gradient(ellipse 60% 40% at 50% 55%, rgba(255, 255, 255, 0.85), rgba(240, 235, 228, 0.4) 50%, transparent 70%),
    linear-gradient(180deg, #e8e4dc 0%, #d8d4cc 100%);
}

.cp-ph-img--coffee {
  aspect-ratio: 3 / 3.6;
  background:
    linear-gradient(145deg, rgba(255, 240, 210, 0.4) 0%, transparent 50%),
    linear-gradient(180deg, #c8b8a0 0%, #988870 40%, #786050 100%);
}

.cp-ph-img--shell {
  aspect-ratio: 1;
  background:
    radial-gradient(ellipse 70% 60% at 50% 45%, #fff 0%, #f5f0ea 40%, #e8e0d8 100%);
}

/* new 徽章 */
.cp-ph-badge {
  position: absolute;
  right: -4px;
  bottom: 8px;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 6;
}

.cp-ph-badge span {
  font-size: 5.5px;
  letter-spacing: 0.06em;
  text-transform: lowercase;
  color: rgba(100, 90, 80, 0.7);
  line-height: 1;
}

.cp-ph-badge i {
  font-style: normal;
  font-size: 6px;
  color: rgba(180, 160, 130, 0.8);
  margin-top: 1px;
}

/* 便签 */
.cp-ph-note {
  background: var(--ph-paper-warm);
  box-shadow: 0 6px 18px rgba(60, 50, 40, 0.12);
}

.cp-ph-note__text {
  margin: 0;
  padding: 14px 10px 10px;
  font-family: 'Great Vibes', cursive;
  font-size: clamp(11px, 3.2vw, 14px);
  line-height: 1.35;
  color: rgba(90, 78, 68, 0.72);
  text-align: center;
}

.cp-ph-note__star {
  position: absolute;
  right: 8px;
  bottom: 6px;
  font-size: 8px;
  color: rgba(160, 140, 110, 0.45);
}

.cp-ph-note--lined {
  padding: 12px 10px 16px;
  background: #f5f0e8;
  background-image: repeating-linear-gradient(
    transparent,
    transparent 13px,
    rgba(180, 170, 155, 0.25) 13px,
    rgba(180, 170, 155, 0.25) 14px
  );
  background-position: 0 22px;
}

.cp-ph-note__title {
  margin: 0 0 8px;
  font-family: 'Great Vibes', cursive;
  font-size: 13px;
  color: rgba(90, 78, 68, 0.75);
  background: #f5f0e8;
  position: relative;
  z-index: 1;
}

.cp-ph-note__list {
  margin: 0;
  padding: 0 0 0 14px;
  list-style: none;
  position: relative;
  z-index: 1;
}

.cp-ph-note__list li {
  font-size: 7.5px;
  line-height: 14px;
  color: rgba(90, 78, 68, 0.58);
  position: relative;
}

.cp-ph-note__list li::before {
  content: '·';
  position: absolute;
  left: -10px;
  color: rgba(140, 120, 100, 0.5);
}

.cp-ph-note__leaf {
  position: absolute;
  right: 6px;
  bottom: 4px;
  width: 16px;
  height: 20px;
  background: radial-gradient(ellipse at 50% 80%, rgba(120, 140, 90, 0.35), transparent 70%);
  border-radius: 0 0 50% 50%;
  transform: rotate(15deg);
}

/* 干花 */
.cp-ph-flower {
  width: 8px;
  height: 52px;
  background: linear-gradient(180deg, rgba(180, 160, 130, 0.5) 0%, rgba(160, 140, 110, 0.35) 100%);
  border-radius: 2px;
  transform: rotate(8deg);
}

.cp-ph-flower::before {
  content: '';
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 14px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(220, 200, 180, 0.6), rgba(180, 160, 140, 0.3));
}

/* 拼贴位置 */
.cp-ph-item--p1 {
  left: 3%;
  top: 0;
  width: 34%;
  transform: rotate(-1.5deg);
  z-index: 3;
}

.cp-ph-item--note1 {
  left: 36%;
  top: 1%;
  width: 24%;
  transform: rotate(2deg);
  z-index: 2;
}

.cp-ph-item--p2 {
  right: 0;
  top: 2%;
  width: 34%;
  transform: rotate(2.5deg);
  z-index: 4;
}

.cp-ph-item--p3 {
  left: 30%;
  top: 34%;
  width: 28%;
  transform: rotate(-1deg);
  z-index: 3;
}

.cp-ph-item--p4 {
  right: 2%;
  top: 36%;
  width: 30%;
  transform: rotate(1.5deg);
  z-index: 4;
}

.cp-ph-item--todo {
  left: 0;
  top: 58%;
  width: 32%;
  transform: rotate(-2deg);
  z-index: 2;
}

.cp-ph-item--p5 {
  left: 30%;
  top: 66%;
  width: 24%;
  transform: rotate(1deg);
  z-index: 3;
}

.cp-ph-item--flower {
  right: 16%;
  top: 70%;
  z-index: 2;
}

/* ── 右侧工具栏 ── */
.cp-ph-rail {
  position: absolute;
  top: calc(env(safe-area-inset-top, 0px) + 280px);
  right: 10px;
  z-index: 25;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.cp-ph-rail__btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.82);
  cursor: pointer;
  padding: 4px;
  -webkit-appearance: none;
  appearance: none;
}

.cp-ph-rail__btn:active { opacity: 0.65; }

.cp-ph-rail__icon {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cp-ph-rail__icon svg { width: 100%; height: 100%; }

.cp-ph-rail__label {
  font-size: 8.5px;
  letter-spacing: 0.04em;
  opacity: 0.75;
}

/* ── 底部 ── */
.cp-ph-foot {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  padding: 0 12px calc(env(safe-area-inset-bottom, 0px) + 10px);
}

.cp-ph-profile {
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: 0;
  margin-bottom: 10px;
  min-height: 72px;
}

.cp-ph-dome {
  position: relative;
  width: 56px;
  height: 64px;
  flex-shrink: 0;
  margin-left: 2px;
  margin-bottom: 2px;
}

.cp-ph-dome__glass {
  position: absolute;
  left: 4px;
  top: 0;
  width: 48px;
  height: 48px;
  border-radius: 50% 50% 45% 45%;
  background:
    radial-gradient(ellipse 80% 60% at 30% 25%, rgba(255, 255, 255, 0.35), transparent),
    radial-gradient(circle at 50% 60%, rgba(200, 210, 220, 0.15), rgba(180, 190, 200, 0.08));
  border: 1px solid rgba(255, 255, 255, 0.25);
  box-shadow: inset 0 -8px 12px rgba(180, 190, 200, 0.12);
}

.cp-ph-dome__bear {
  position: absolute;
  left: 50%;
  top: 18px;
  transform: translateX(-50%);
  width: 14px;
  height: 16px;
  background: #f5f0ea;
  border-radius: 40% 40% 45% 45%;
  box-shadow: inset 0 -2px 0 rgba(200, 190, 180, 0.3);
}

.cp-ph-dome__bear::before,
.cp-ph-dome__bear::after {
  content: '';
  position: absolute;
  top: -4px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #f5f0ea;
}

.cp-ph-dome__bear::before { left: -1px; }
.cp-ph-dome__bear::after { right: -1px; }

.cp-ph-dome__base {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 56px;
  height: 14px;
  border-radius: 4px;
  background: linear-gradient(180deg, #c8b8a8, #a89888);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

.cp-ph-profile__info {
  position: relative;
  margin-left: 8px;
  margin-bottom: 8px;
  padding-left: 4px;
}

.cp-ph-profile__arc {
  position: absolute;
  left: -18px;
  top: -28px;
  width: 100px;
  height: 70px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 50%;
  border-bottom-color: transparent;
  border-left-color: transparent;
  transform: rotate(-20deg);
  pointer-events: none;
}

.cp-ph-profile__arc::after {
  content: '✦';
  position: absolute;
  right: 8px;
  bottom: 2px;
  font-size: 8px;
  color: rgba(255, 255, 255, 0.45);
}

.cp-ph-profile__name {
  margin: 0;
  font-family: 'Great Vibes', cursive;
  font-size: clamp(24px, 7vw, 30px);
  line-height: 1;
  color: rgba(255, 255, 255, 0.95);
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.1);
}

.cp-ph-profile__level {
  margin: 3px 0 0;
  font-size: 9px;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.65);
}

.cp-ph-profile__bar {
  margin-top: 5px;
  width: 110px;
  height: 3px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  overflow: hidden;
}

.cp-ph-profile__bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.45), rgba(255, 255, 255, 0.78));
}

.cp-ph-profile__xp {
  margin: 4px 0 0;
  font-size: 8px;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.42);
}

/* 合集卡片 */
.cp-ph-collections {
  margin: 0 0 0 26%;
  overflow: hidden;
}

.cp-ph-collections[hidden] { display: none !important; }

.cp-ph-collections__track {
  display: flex;
  gap: 7px;
  transition: transform 0.38s cubic-bezier(0.22, 1, 0.36, 1);
  transform: translateX(calc(var(--ph-col-page, 0) * (-100% - 7px)));
}

.cp-ph-col-page {
  display: flex;
  gap: 7px;
  flex: 0 0 100%;
  min-width: 100%;
}

.cp-ph-col-card {
  flex: 1;
  min-width: 0;
  border: none;
  padding: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
  color: inherit;
  -webkit-appearance: none;
  appearance: none;
}

.cp-ph-col-card:active { opacity: 0.8; }

.cp-ph-col-card__inner {
  position: relative;
  border-radius: 10px;
  padding: 8px 7px 7px;
  min-height: 52px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  overflow: hidden;
}

.cp-ph-col-card__title {
  display: block;
  font-size: 8px;
  line-height: 1.25;
  color: rgba(255, 255, 255, 0.9);
  max-width: calc(100% - 30px);
}

.cp-ph-col-card__count {
  display: block;
  margin-top: 4px;
  font-size: 7.5px;
  letter-spacing: 0.06em;
  color: rgba(255, 255, 255, 0.48);
}

.cp-ph-col-card__thumb {
  position: absolute;
  right: 5px;
  bottom: 5px;
  width: 26px;
  height: 26px;
  border-radius: 5px;
  background-color: rgba(255, 255, 255, 0.12);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  opacity: 0.88;
}

/* 分页点 */
.cp-ph-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 10px;
}

.cp-ph-dots[hidden] { display: none !important; }

.cp-ph-dots__dot {
  width: 5px;
  height: 5px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.28);
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

.cp-ph-dots__dot.is-active {
  background: rgba(255, 255, 255, 0.88);
  transform: scale(1.12);
}

/* ── 前景装饰 ── */
.cp-ph-fg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 40;
}

.cp-ph-fg__desk {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 18%;
  background: linear-gradient(180deg, transparent 0%, rgba(160, 140, 115, 0.15) 40%, rgba(140, 120, 95, 0.35) 100%);
}

.cp-ph-fg__plant {
  position: absolute;
  left: -8%;
  bottom: 8%;
  width: 28%;
  height: 22%;
  background:
    radial-gradient(ellipse 40% 60% at 70% 40%, rgba(80, 110, 60, 0.35), transparent),
    radial-gradient(ellipse 50% 40% at 40% 60%, rgba(60, 90, 50, 0.25), transparent);
  filter: blur(6px);
  transform: rotate(-12deg);
}

.cp-ph-fg__stones {
  position: absolute;
  right: 4%;
  bottom: 6%;
  width: 18%;
  height: 10%;
  background:
    radial-gradient(circle at 30% 60%, rgba(220, 210, 200, 0.4), transparent 50%),
    radial-gradient(circle at 60% 40%, rgba(200, 190, 180, 0.35), transparent 45%);
  filter: blur(4px);
}
