:root {
  --ink: #211e22;
  --muted: #716b72;
  --paper: #fbf8f4;
  --line: #ddd2ca;
  --rose: #a93457;
  --teal: #167d78;
  --gold: #bd8a32;
  --violet: #62558f;
  --mint: #d7ebe5;
  --shadow: 0 18px 54px rgba(30, 24, 29, 0.18);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: "Avenir Next", Inter, ui-sans-serif, system-ui, sans-serif;
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.5), transparent 34%),
    radial-gradient(circle at 12% 8%, rgba(189, 138, 50, 0.18), transparent 22rem),
    radial-gradient(circle at 90% 6%, rgba(22, 125, 120, 0.14), transparent 24rem),
    linear-gradient(135deg, #f6f0ea 0%, #f9f7f3 43%, #e9f0ed 100%);
}

body[data-view="beaute"] {
  background:
    radial-gradient(circle at 50% -6%, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.7) 34rem, transparent 35rem),
    linear-gradient(180deg, #fbfbfc 0%, #f7f4fa 44%, #efe4fb 100%);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.28;
  background-image:
    linear-gradient(rgba(33, 30, 34, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(33, 30, 34, 0.025) 1px, transparent 1px);
  background-size: 28px 28px;
}

button,
input {
  font: inherit;
}

button {
  border: 1px solid rgba(33, 30, 34, 0.08);
  border-radius: 8px;
  min-height: 42px;
  padding: 0 14px;
  color: #fff;
  background: linear-gradient(180deg, #333036, #1f1d21);
  box-shadow: 0 10px 22px rgba(33, 30, 34, 0.16);
  font-weight: 750;
}

button:active {
  transform: translateY(1px);
}

.app-shell {
  width: min(1120px, 100%);
  margin: 0 auto;
  padding: 16px;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 2px 14px;
}

.eyebrow {
  margin: 0 0 2px;
  color: var(--rose);
  font-size: 0.78rem;
  font-weight: 900;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  margin-bottom: 0;
  font-size: clamp(1.55rem, 5vw, 2.4rem);
  letter-spacing: 0;
}

h2 {
  margin-bottom: 0;
  font-size: 1.05rem;
}

h3 {
  margin: 14px 0 8px;
  font-size: 0.94rem;
}

.wallet {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: max-content;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(14px);
  font-weight: 900;
}

.coin,
.gem,
.trophy {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  color: #fff;
  font-size: 0.8rem;
}

.coin {
  background: var(--gold);
}

.trophy {
  background: var(--teal);
}

.gem {
  background: var(--violet);
}

.workspace {
  display: grid;
  grid-template-columns: minmax(310px, 0.92fr) minmax(340px, 1.08fr);
  gap: 16px;
  align-items: start;
}

.stage,
.controls {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(18px);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.contest-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 58px;
  padding: 12px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(248, 243, 238, 0.88));
  font-weight: 900;
}

.contest-banner button,
.section-head button,
.mini-games button {
  color: var(--ink);
  background: linear-gradient(180deg, #f7f1ea, #e6dbd2);
  border-color: rgba(33, 30, 34, 0.08);
  box-shadow: none;
}

.runway {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 720px;
  overflow: hidden;
  border-radius: 0 0 32px 32px;
  background:
    radial-gradient(circle at 76% 19%, rgba(255, 255, 255, 0.28), transparent 9rem),
    radial-gradient(circle at 30% 33%, rgba(255, 212, 73, 0.38), transparent 10rem),
    linear-gradient(180deg, #4f118c 0%, #8e43df 27%, #c58ff1 48%, #30113f 100%);
}

body[data-view="beaute"] .stage {
  border-color: rgba(98, 28, 146, 0.12);
  border-radius: 32px;
  background: transparent;
  box-shadow: 0 28px 80px rgba(53, 13, 78, 0.22);
}

.runway::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.2) 0 28px, transparent 29px),
    radial-gradient(circle at 30% 12%, rgba(255, 255, 255, 0.15) 0 20px, transparent 21px),
    radial-gradient(circle at 72% 21%, rgba(255, 255, 255, 0.2) 0 25px, transparent 26px),
    radial-gradient(circle at 90% 12%, rgba(255, 255, 255, 0.14) 0 18px, transparent 19px),
    linear-gradient(120deg, rgba(255, 255, 255, 0.08), transparent 34%, rgba(255, 255, 255, 0.1));
}

.runway::after {
  content: "";
  position: absolute;
  left: 11%;
  right: 11%;
  bottom: 18px;
  height: 250px;
  background:
    linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.22), transparent),
    repeating-linear-gradient(90deg, rgba(86, 72, 70, 0.12) 0 1px, transparent 1px 34px);
  clip-path: polygon(32% 0, 68% 0, 100% 100%, 0 100%);
  opacity: 0.75;
}

.spotlight {
  position: absolute;
  top: 80px;
  width: 410px;
  height: 580px;
  background: radial-gradient(ellipse at center, rgba(255, 238, 183, 0.44), rgba(255, 255, 255, 0.02) 67%);
  transform: perspective(360px) rotateX(18deg);
}

.glam-bokeh {
  position: absolute;
  inset: 92px 0 0;
  z-index: 0;
  background-image:
    radial-gradient(circle, rgba(255, 225, 76, 0.8) 0 5px, transparent 6px),
    radial-gradient(circle, rgba(255, 168, 92, 0.45) 0 4px, transparent 5px),
    radial-gradient(circle, rgba(255, 255, 255, 0.22) 0 6px, transparent 7px);
  background-position: 14px 140px, 80px 190px, 34px 20px;
  background-size: 82px 76px, 116px 92px, 134px 118px;
  opacity: 0.72;
  filter: blur(0.2px);
}

body[data-view="beaute"] .glam-bokeh {
  inset: 108px 0 0;
  opacity: 0.96;
  background-image:
    radial-gradient(circle, rgba(255, 224, 70, 0.88) 0 5px, transparent 6px),
    radial-gradient(circle, rgba(255, 157, 87, 0.48) 0 4px, transparent 5px),
    radial-gradient(circle, rgba(255, 255, 255, 0.2) 0 12px, transparent 13px);
  background-position: 8px 122px, 70px 174px, 34px 12px;
  background-size: 64px 58px, 96px 82px, 130px 112px;
}

.glam-banner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 3;
  height: 104px;
  display: grid;
  place-items: center;
  border-bottom: 4px solid #f4d457;
  background:
    radial-gradient(circle at 15% 45%, rgba(255, 255, 255, 0.16) 0 30px, transparent 31px),
    radial-gradient(circle at 38% 28%, rgba(255, 255, 255, 0.12) 0 48px, transparent 49px),
    linear-gradient(120deg, #7d1dc8, #3b0d78 58%, #22063e);
}

.glam-banner span {
  color: #fff;
  font-size: clamp(2rem, 7vw, 3.8rem);
  font-weight: 950;
  letter-spacing: 0;
}

body[data-view="beaute"] .glam-banner {
  height: 112px;
  border-bottom-color: #f6d95b;
  background:
    radial-gradient(circle at 14% 58%, rgba(255, 255, 255, 0.16) 0 30px, transparent 31px),
    radial-gradient(circle at 36% 32%, rgba(255, 255, 255, 0.12) 0 45px, transparent 46px),
    radial-gradient(circle at 82% 52%, rgba(255, 255, 255, 0.18) 0 38px, transparent 39px),
    linear-gradient(130deg, #a234df 0%, #5514a1 56%, #21043c 100%);
}

body[data-view="beaute"] .glam-banner span {
  font-size: clamp(2.7rem, 9vw, 5.4rem);
  line-height: 1;
}

.catwalk {
  position: absolute;
  bottom: -54px;
  width: 78%;
  height: 188px;
  border-radius: 50% 50% 0 0;
  background:
    radial-gradient(ellipse at top, rgba(255, 255, 255, 0.72), transparent 52%),
    linear-gradient(180deg, rgba(255, 232, 247, 0.85), rgba(80, 22, 112, 0.48));
  border: 1px solid rgba(33, 30, 34, 0.12);
  box-shadow: 0 -18px 50px rgba(33, 30, 34, 0.2) inset;
}

.model-wrap {
  position: relative;
  z-index: 1;
  width: 300px;
  height: 640px;
  display: grid;
  place-items: end center;
  transition: transform 0.35s ease;
}

.model-wrap.walk {
  animation: walk 2.2s ease-in-out;
}

@keyframes walk {
  0% { transform: translateX(-95px) scale(0.9); }
  45% { transform: translateX(0) scale(1.02); }
  100% { transform: translateX(95px) scale(0.94); }
}

.model {
  position: relative;
  width: 260px;
  height: 620px;
  filter: drop-shadow(0 26px 22px rgba(28, 23, 25, 0.22));
}

.editorial-avatar {
  position: absolute;
  inset: 0;
  isolation: isolate;
  --skin-tone: #c99274;
  --skin-shade: #9b654e;
  --hair-tone: #342528;
  --dress-shadow: rgba(18, 12, 16, 0.24);
  transform-origin: center bottom;
}

body[data-view="beaute"] .editorial-avatar::before,
body[data-view="beaute"] .editorial-avatar::after {
  content: "";
  position: absolute;
  top: 98px;
  z-index: 11;
  width: 13px;
  height: 28px;
  border-radius: 50% 50% 44% 44%;
  background:
    radial-gradient(circle at 50% 75%, #6e22b3 0 6px, transparent 7px),
    radial-gradient(circle at 50% 24%, #f7e8ff 0 3px, #6e22b3 4px 6px, transparent 7px);
  box-shadow:
    0 0 0 2px rgba(239, 225, 255, 0.9),
    0 4px 8px rgba(32, 12, 42, 0.18);
}

body[data-view="beaute"] .editorial-avatar::before {
  left: 75px;
}

body[data-view="beaute"] .editorial-avatar::after {
  right: 75px;
}

.avatar-shadow {
  position: absolute;
  left: 54px;
  bottom: 4px;
  width: 154px;
  height: 26px;
  border-radius: 50%;
  background: rgba(18, 14, 15, 0.22);
  filter: blur(8px);
  z-index: 0;
}

.avatar-body,
.avatar-body span,
.garment-layer,
.garment-layer span,
.garment-accessory,
.avatar-hair {
  position: absolute;
}

.avatar-body {
  inset: 0;
  z-index: 5;
}

body[data-view="beaute"] .avatar-body::before,
body[data-view="beaute"] .avatar-body::after {
  content: "";
  position: absolute;
  top: 58px;
  z-index: 6;
  width: 50px;
  height: 286px;
  border-radius: 34px 34px 28px 28px;
  background:
    linear-gradient(100deg, rgba(255, 255, 255, 0.2), transparent 28%, rgba(0, 0, 0, 0.24)),
    repeating-linear-gradient(96deg, rgba(255, 255, 255, 0.14) 0 2px, transparent 2px 9px),
    var(--hair-tone);
  box-shadow: inset -18px -32px 26px rgba(0, 0, 0, 0.22);
}

body[data-view="beaute"] .avatar-body::before {
  left: 46px;
  transform: rotate(5deg);
  clip-path: polygon(0 0, 100% 12%, 86% 100%, 20% 86%);
}

body[data-view="beaute"] .avatar-body::after {
  right: 46px;
  transform: rotate(-5deg);
  clip-path: polygon(0 12%, 100% 0, 80% 86%, 14% 100%);
}

.avatar-head {
  top: 53px;
  left: 89px;
  width: 82px;
  height: 101px;
  border-radius: 44% 44% 46% 46%;
  background:
    radial-gradient(ellipse at 50% 24%, rgba(255, 255, 255, 0.42), transparent 24%),
    radial-gradient(circle at 35% 66%, rgba(239, 129, 148, 0.18), transparent 16%),
    radial-gradient(circle at 65% 66%, rgba(239, 129, 148, 0.18), transparent 16%),
    linear-gradient(100deg, rgba(255, 255, 255, 0.16), transparent 42%, rgba(75, 37, 31, 0.18)),
    var(--skin-tone);
  box-shadow:
    inset -10px -12px 18px rgba(95, 48, 38, 0.14),
    0 9px 22px rgba(70, 28, 34, 0.16);
  z-index: 5;
}

body[data-view="beaute"] .avatar-head {
  top: 42px;
  left: 82px;
  width: 96px;
  height: 116px;
  border-radius: 45% 45% 48% 48%;
  background:
    radial-gradient(ellipse at 50% 18%, rgba(255, 255, 255, 0.54), transparent 26%),
    radial-gradient(circle at 30% 65%, rgba(236, 126, 144, 0.2), transparent 17%),
    radial-gradient(circle at 70% 65%, rgba(236, 126, 144, 0.2), transparent 17%),
    linear-gradient(100deg, rgba(255, 255, 255, 0.22), transparent 42%, rgba(75, 37, 31, 0.2)),
    var(--skin-tone);
  box-shadow:
    inset -13px -15px 22px rgba(95, 48, 38, 0.16),
    0 12px 26px rgba(70, 28, 34, 0.16);
}

.avatar-head::before,
.avatar-head::after {
  content: "";
  position: absolute;
  top: 46px;
  width: 11px;
  height: 21px;
  border-radius: 50%;
  background: var(--skin-tone);
  box-shadow: inset -3px -3px 6px rgba(95, 48, 38, 0.12);
}

.avatar-head::before {
  left: -7px;
}

.avatar-head::after {
  right: -7px;
}

.avatar-face {
  inset: 0;
}

body[data-view="beaute"] .avatar-face::before {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  top: -3px;
  height: 26px;
  border-radius: 42px 42px 20px 20px;
  background:
    linear-gradient(105deg, rgba(255, 255, 255, 0.18), transparent 38%, rgba(0, 0, 0, 0.18)),
    repeating-linear-gradient(96deg, rgba(255, 255, 255, 0.16) 0 2px, transparent 2px 9px),
    var(--hair-tone);
}


.avatar-eye {
  top: 45px;
  width: 15px;
  height: 8px;
  border-radius: 50%;
  background:
    linear-gradient(180deg, rgba(187, 234, 108, 0.95), rgba(88, 53, 130, 0.72) 45%, transparent 47%),
    radial-gradient(circle at 62% 47%, #fff 0 1px, #4b2f21 2px 4px, #171313 5px);
  box-shadow: 0 -3px 0 rgba(41, 24, 32, 0.78), 0 3px 0 rgba(94, 57, 144, 0.5);
}

body[data-view="beaute"] .avatar-eye {
  top: 50px;
  width: 20px;
  height: 10px;
  background:
    linear-gradient(180deg, rgba(219, 241, 89, 0.98), rgba(88, 46, 152, 0.84) 45%, transparent 47%),
    radial-gradient(circle at 62% 48%, #fff 0 1px, #b47731 2px 4px, #1b1413 5px);
  box-shadow:
    0 -4px 0 rgba(35, 23, 30, 0.86),
    0 4px 0 rgba(97, 49, 158, 0.62),
    0 0 0 2px rgba(255, 255, 255, 0.4);
}

body[data-view="beaute"] .avatar-eye.left {
  left: 21px;
}

body[data-view="beaute"] .avatar-eye.right {
  right: 21px;
}

.avatar-eye.left {
  left: 20px;
}

.avatar-eye.right {
  right: 20px;
}

.avatar-brow {
  top: 37px;
  width: 18px;
  height: 6px;
  border-top: 2px solid rgba(38, 28, 28, 0.62);
  border-radius: 50%;
}

body[data-view="beaute"] .avatar-brow {
  top: 38px;
  width: 24px;
  border-top-width: 3px;
}

.avatar-brow.left {
  left: 19px;
  transform: rotate(7deg);
}

.avatar-brow.right {
  right: 19px;
  transform: rotate(-7deg);
}

.avatar-nose {
  top: 50px;
  left: 39px;
  width: 8px;
  height: 19px;
  border-right: 2px solid rgba(88, 53, 46, 0.28);
  border-bottom: 1px solid rgba(88, 53, 46, 0.18);
  border-radius: 0 0 8px 0;
}

body[data-view="beaute"] .avatar-nose {
  top: 58px;
  left: 45px;
  width: 10px;
  height: 23px;
}

.avatar-mouth {
  left: 32px;
  top: 76px;
  width: 22px;
  height: 8px;
  border-bottom: 5px solid var(--lip, #b53657);
  border-radius: 0 0 50% 50%;
  filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.4));
}

body[data-view="beaute"] .avatar-mouth {
  left: 35px;
  top: 88px;
  width: 28px;
  height: 11px;
  border-bottom-width: 7px;
  box-shadow: inset 0 2px 0 rgba(255, 255, 255, 0.36);
}

.avatar-blush {
  top: 63px;
  width: 18px;
  height: 10px;
  border-radius: 50%;
  background: rgba(224, 111, 126, 0.42);
  opacity: var(--blush, 0.4);
}

.avatar-blush.left {
  left: 12px;
}

.avatar-blush.right {
  right: 12px;
}

.avatar-neck {
  top: 144px;
  left: 111px;
  width: 38px;
  height: 54px;
  border-radius: 0 0 18px 18px;
  background:
    linear-gradient(90deg, rgba(82, 43, 35, 0.16), transparent 44%, rgba(255, 255, 255, 0.08)),
    var(--skin-tone);
  z-index: 3;
}

.avatar-torso {
  top: 181px;
  left: 74px;
  width: 112px;
  height: 170px;
  border-radius: 48% 48% 34% 34%;
  background:
    radial-gradient(ellipse at 48% 10%, rgba(255, 255, 255, 0.18), transparent 26%),
    linear-gradient(90deg, rgba(84, 43, 36, 0.18), transparent 45%, rgba(255, 255, 255, 0.12)),
    var(--skin-tone);
  clip-path: polygon(22% 0, 78% 0, 92% 25%, 80% 100%, 20% 100%, 8% 25%);
  z-index: 2;
}

.avatar-arm {
  top: 196px;
  width: 24px;
  height: 192px;
  border-radius: 16px;
  background:
    linear-gradient(90deg, rgba(76, 37, 32, 0.18), transparent 42%, rgba(255, 255, 255, 0.12)),
    var(--skin-tone);
  transform-origin: top center;
  z-index: 2;
}

.avatar-arm.left {
  left: 49px;
  transform: rotate(19deg);
}

.avatar-arm.right {
  right: 49px;
  transform: rotate(-19deg);
}

.avatar-hand {
  left: -2px;
  bottom: -14px;
  width: 27px;
  height: 27px;
  border-radius: 50%;
  background: var(--skin-tone);
  box-shadow: inset -5px -4px 8px rgba(75, 37, 32, 0.14);
}

.avatar-leg {
  top: 346px;
  width: 23px;
  height: 241px;
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(76, 37, 32, 0.18), transparent 42%, rgba(255, 255, 255, 0.12)),
    var(--skin-tone);
  z-index: 1;
}

.avatar-leg.left {
  left: 103px;
  transform: rotate(8deg);
}

.avatar-leg.right {
  right: 101px;
  transform: rotate(-2deg);
}

.avatar-shoe {
  top: 575px;
  width: 42px;
  height: 17px;
  border-radius: 50% 50% 8px 8px;
  background: linear-gradient(180deg, #2c272d, #0d0c0e);
  z-index: 4;
}

.avatar-shoe.left {
  left: 84px;
  transform: rotate(8deg);
}

.avatar-shoe.right {
  right: 79px;
}

.avatar-hair {
  top: 28px;
  left: 35px;
  width: 190px;
  height: 360px;
  border-radius: 96px 96px 58px 58px;
  background:
    radial-gradient(ellipse at 56% 8%, rgba(255, 255, 255, 0.26), transparent 18%),
    linear-gradient(105deg, rgba(255, 255, 255, 0.22), transparent 21%, rgba(0, 0, 0, 0.28)),
    repeating-linear-gradient(102deg, rgba(255, 255, 255, 0.14) 0 2px, transparent 2px 10px),
    var(--hair-tone);
  box-shadow:
    inset -26px -40px 34px rgba(0, 0, 0, 0.26),
    inset 18px 0 28px rgba(255, 255, 255, 0.07);
  z-index: 3;
  clip-path: polygon(12% 0, 88% 0, 100% 42%, 92% 100%, 62% 84%, 50% 25%, 38% 84%, 8% 100%, 0 42%);
}

body[data-view="beaute"] .avatar-hair {
  top: 6px;
  left: -8px;
  width: 276px;
  height: 468px;
  border-radius: 142px 142px 82px 82px;
  background:
    radial-gradient(ellipse at 53% 9%, rgba(255, 255, 255, 0.24), transparent 16%),
    linear-gradient(103deg, rgba(255, 255, 255, 0.22), transparent 18%, rgba(0, 0, 0, 0.34)),
    repeating-linear-gradient(101deg, rgba(255, 255, 255, 0.16) 0 2px, transparent 2px 11px),
    repeating-linear-gradient(77deg, transparent 0 11px, rgba(0, 0, 0, 0.12) 11px 14px),
    var(--hair-tone);
  clip-path: polygon(12% 0, 88% 0, 100% 36%, 93% 100%, 64% 82%, 51% 21%, 37% 82%, 7% 100%, 0 36%);
  box-shadow:
    inset -38px -58px 48px rgba(0, 0, 0, 0.32),
    inset 28px 0 34px rgba(255, 255, 255, 0.08),
    0 18px 30px rgba(30, 10, 28, 0.18);
}

body[data-view="beaute"] .avatar-hair::before {
  height: 330px;
  background: rgba(255, 255, 255, 0.3);
}

.avatar-hair::before {
  content: "";
  position: absolute;
  left: 49%;
  top: 0;
  width: 2px;
  height: 220px;
  background: rgba(255, 255, 255, 0.26);
  box-shadow:
    -28px 30px 0 -1px rgba(255, 255, 255, 0.12),
    33px 34px 0 -1px rgba(255, 255, 255, 0.1);
}

.editorial-avatar[data-hair="curls"] .avatar-hair {
  border-radius: 50%;
  width: 136px;
  left: 62px;
  height: 150px;
  box-shadow:
    -18px 34px 0 -12px var(--hair-tone),
    18px 34px 0 -12px var(--hair-tone),
    inset -18px -28px 28px rgba(0, 0, 0, 0.2);
}

.editorial-avatar[data-hair="braid"] .avatar-hair::after {
  content: "";
  position: absolute;
  right: -18px;
  top: 96px;
  width: 28px;
  height: 166px;
  border-radius: 18px;
  background: repeating-linear-gradient(180deg, var(--hair-tone) 0 18px, rgba(255, 255, 255, 0.22) 18px 22px);
}

body[data-view="beaute"] .editorial-avatar[data-hair="curls"] .avatar-hair,
body[data-view="beaute"] .editorial-avatar[data-hair="braid"] .avatar-hair {
  top: 6px;
  left: -8px;
  width: 276px;
  height: 468px;
  border-radius: 142px 142px 82px 82px;
  background:
    radial-gradient(ellipse at 53% 9%, rgba(255, 255, 255, 0.24), transparent 16%),
    linear-gradient(103deg, rgba(255, 255, 255, 0.22), transparent 18%, rgba(0, 0, 0, 0.34)),
    repeating-linear-gradient(101deg, rgba(255, 255, 255, 0.16) 0 2px, transparent 2px 11px),
    var(--hair-tone);
  clip-path: polygon(12% 0, 88% 0, 100% 36%, 93% 100%, 64% 82%, 51% 21%, 37% 82%, 7% 100%, 0 36%);
  box-shadow:
    inset -38px -58px 48px rgba(0, 0, 0, 0.32),
    inset 28px 0 34px rgba(255, 255, 255, 0.08),
    0 18px 30px rgba(30, 10, 28, 0.18);
}

body[data-view="beaute"] .editorial-avatar[data-hair="curls"] .avatar-hair {
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.16) 0 5px, transparent 6px),
    radial-gradient(ellipse at 53% 9%, rgba(255, 255, 255, 0.24), transparent 16%),
    linear-gradient(103deg, rgba(255, 255, 255, 0.18), transparent 18%, rgba(0, 0, 0, 0.34)),
    var(--hair-tone);
  background-size: 28px 28px, auto, auto, auto;
}

body[data-view="beaute"] .editorial-avatar[data-hair="braid"] .avatar-hair::after {
  right: 18px;
  top: 158px;
  width: 34px;
  height: 230px;
  border-radius: 20px;
}

.garment-layer {
  left: 65px;
  width: 130px;
  overflow: hidden;
  z-index: 7;
  background:
    radial-gradient(ellipse at 36% 12%, rgba(255, 255, 255, 0.48), transparent 24%),
    linear-gradient(100deg, rgba(255, 255, 255, 0.2), transparent 31%, var(--dress-shadow)),
    var(--dress);
  box-shadow:
    0 8px 18px rgba(18, 12, 16, 0.18),
    inset -18px -24px 28px rgba(23, 12, 18, 0.18);
}

body[data-view="beaute"] .runway {
  min-height: 700px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 50% 33%, rgba(255, 232, 170, 0.42), transparent 13rem),
    radial-gradient(circle at 74% 20%, rgba(255, 255, 255, 0.24), transparent 9rem),
    linear-gradient(180deg, #4e138c 0%, #9d58e5 35%, #d1abf2 59%, #311040 100%);
}

body[data-view="beaute"] .contest-banner {
  display: none;
}

body[data-view="beaute"] .model-wrap {
  transform: translateY(158px) scale(2.25);
  transform-origin: center 22%;
  z-index: 2;
}

body[data-view="beaute"] .catwalk {
  display: none;
}

body[data-view="beaute"] .garment-skirt,
body[data-view="beaute"] .avatar-leg,
body[data-view="beaute"] .avatar-shoe,
body[data-view="beaute"] .avatar-arm,
body[data-view="beaute"] .avatar-hand {
  opacity: 0;
}

body[data-view="beaute"] .garment-top {
  top: 184px;
  left: 52px;
  width: 156px;
  height: 164px;
  border-radius: 30px 30px 0 0;
  clip-path: polygon(22% 0, 42% 0, 50% 20%, 58% 0, 78% 0, 100% 100%, 0 100%);
  background:
    radial-gradient(ellipse at 34% 9%, rgba(255, 255, 255, 0.58), transparent 25%),
    linear-gradient(103deg, rgba(255, 255, 255, 0.3), transparent 36%, rgba(43, 8, 70, 0.34)),
    linear-gradient(180deg, #b88cff 0%, #7f40c8 100%);
}

body[data-view="beaute"] .garment-pattern {
  opacity: 0.32;
}

body[data-view="beaute"] .necklace-layer,
body[data-view="beaute"] .necklace-layer.on {
  display: block;
  top: 171px;
  left: 99px;
  width: 62px;
  height: 38px;
  border-bottom: 3px dotted #efe1ff;
  box-shadow: 0 8px 0 -5px rgba(80, 34, 138, 0.82);
  z-index: 12;
}

.beauty-tray {
  position: absolute;
  left: 7%;
  right: 7%;
  bottom: 18px;
  z-index: 9;
  display: none;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

body[data-view="beaute"] .beauty-tray {
  display: grid;
}

.beauty-thumb {
  position: relative;
  aspect-ratio: 1;
  min-height: 0;
  padding: 0;
  border: 3px solid rgba(255, 255, 255, 0.9);
  border-radius: 14px;
  background:
    radial-gradient(ellipse at 50% 35%, #f4c9b7 0 28%, transparent 29%),
    linear-gradient(180deg, #fff, #f4edf4);
  box-shadow: 0 10px 24px rgba(20, 8, 28, 0.32);
  overflow: hidden;
}

body[data-view="beaute"] .beauty-thumb {
  border-radius: 16px;
  box-shadow: 0 12px 28px rgba(20, 8, 28, 0.34), inset 0 0 0 1px rgba(255, 255, 255, 0.4);
}

.beauty-thumb::before {
  content: "";
  position: absolute;
  left: 19%;
  right: 19%;
  top: 10%;
  height: 58%;
  border-radius: 48% 48% 42% 42%;
  background: #f1c2ad;
  box-shadow: inset -7px -7px 12px rgba(92, 46, 35, 0.12);
}

.beauty-thumb::after {
  content: "";
  position: absolute;
  left: 14%;
  right: 14%;
  top: 3%;
  height: 54%;
  border-radius: 45% 45% 28% 28%;
  background:
    repeating-linear-gradient(100deg, rgba(255, 255, 255, 0.18) 0 2px, transparent 2px 8px),
    #3b2521;
  clip-path: polygon(0 0, 100% 0, 94% 100%, 64% 62%, 50% 20%, 36% 62%, 6% 100%);
}

.beauty-thumb.two::before {
  background: #9a684d;
}

.beauty-thumb.three::after {
  background: #b45366;
}

.beauty-thumb.four::before {
  background: #b7795b;
}

.beauty-thumb.hair::before {
  top: 18%;
}

.beauty-thumb.hair.one::after {
  background: #d2aa62;
}

.beauty-thumb.hair.two::after {
  background: #c45265;
}

.beauty-thumb.hair.three::after {
  background:
    radial-gradient(circle, rgba(255,255,255,.15) 0 5px, transparent 6px),
    #7d5a3c;
  background-size: 18px 18px;
}

.beauty-thumb.hair.four::after {
  background: #151218;
}

.garment-top {
  top: 178px;
  height: 108px;
  clip-path: polygon(28% 0, 72% 0, 88% 100%, 12% 100%);
}

.garment-skirt {
  top: 273px;
  height: 142px;
  clip-path: polygon(18% 0, 82% 0, 100% 100%, 0 100%);
}

.editorial-avatar[data-top="heart"] .garment-top {
  clip-path: polygon(26% 8%, 40% 0, 50% 13%, 60% 0, 74% 8%, 88% 100%, 12% 100%);
}

.editorial-avatar[data-top="cape"] .garment-top {
  left: 54px;
  width: 152px;
  clip-path: polygon(16% 0, 84% 0, 96% 100%, 4% 100%);
}

.editorial-avatar[data-skirt="pencil"] .garment-skirt {
  left: 76px;
  width: 108px;
  clip-path: polygon(10% 0, 90% 0, 82% 100%, 18% 100%);
}

.editorial-avatar[data-skirt="wave"] .garment-skirt {
  clip-path: polygon(18% 0, 82% 0, 96% 78%, 82% 100%, 62% 88%, 50% 100%, 38% 88%, 18% 100%, 4% 78%);
}

.garment-pattern,
.garment-material {
  inset: 0;
}

.editorial-avatar[data-pattern="dots"] .garment-pattern {
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.62) 0 4px, transparent 5px);
  background-size: 22px 22px;
}

.editorial-avatar[data-pattern="stripes"] .garment-pattern {
  background-image: repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.42) 0 8px, transparent 8px 18px);
}

.editorial-avatar[data-pattern="flowers"] .garment-pattern {
  background-image:
    radial-gradient(circle at 20% 20%, rgba(255, 247, 166, 0.72) 0 4px, transparent 6px),
    radial-gradient(circle at 70% 55%, rgba(255, 255, 255, 0.62) 0 4px, transparent 5px);
  background-size: 34px 34px;
}

.editorial-avatar[data-material="satin"] .garment-material {
  background: linear-gradient(100deg, transparent 0 30%, rgba(255, 255, 255, 0.42) 44%, transparent 58%);
}

.editorial-avatar[data-material="velvet"] .garment-material {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.27));
}

.editorial-avatar[data-material="tulle"] .garment-material {
  background-image:
    linear-gradient(90deg, rgba(255, 255, 255, 0.26) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, 0.2) 1px, transparent 1px);
  background-size: 12px 12px;
}

.garment-accessory {
  z-index: 9;
  display: none;
}

.belt-layer.on {
  display: block;
  top: 268px;
  left: 76px;
  width: 108px;
  height: 15px;
  border-radius: 999px;
  background: linear-gradient(180deg, #322d31, #111);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.26);
}

.sparkle-layer.on {
  display: block;
  top: 186px;
  left: 78px;
  width: 106px;
  height: 210px;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.92) 0 2px, transparent 3px);
  background-size: 24px 28px;
}

.bow-layer.on {
  display: block;
  top: 258px;
  left: 119px;
  width: 24px;
  height: 18px;
}

.bow-layer.on::before,
.bow-layer.on::after {
  content: "";
  position: absolute;
  top: 0;
  width: 15px;
  height: 18px;
  border-radius: 50% 10px 50% 10px;
  background: #fff6c7;
  border: 1px solid rgba(20, 18, 20, 0.28);
}

.bow-layer.on::before {
  left: -2px;
  transform: rotate(28deg);
}

.bow-layer.on::after {
  right: -2px;
  transform: rotate(-28deg);
}

.necklace-layer.on {
  display: block;
  top: 173px;
  left: 105px;
  width: 50px;
  height: 34px;
  border-bottom: 4px dotted #bd8a32;
  border-radius: 0 0 50% 50%;
}

.croquis {
  display: none;
}

.croquis {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.sketch-lines path,
.sketch-lines circle,
.dress-layer path,
.dress-layer circle,
.top-hands path {
  vector-effect: non-scaling-stroke;
}

.hair-back,
.arm-fill,
.body-fill,
.leg-fill,
.shoe-fill,
.neck-fill,
.head-fill,
.bangs {
  fill: #fffdfa;
  stroke: #151316;
  stroke-width: 3.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hair-back,
.bangs {
  fill: #fff;
}

.hair-locks,
.face-lines,
.hand-lines {
  fill: none;
  stroke: #151316;
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.eye-dot {
  fill: #151316;
}

.hand-fill {
  fill: #fffdfa;
  stroke: #151316;
  stroke-width: 2.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.hand-detail {
  fill: none;
  stroke: #151316;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

#croquisDressTop,
#croquisDressSkirt {
  fill: var(--dress, #c74970);
  stroke: #151316;
  stroke-width: 2.8;
  stroke-linejoin: round;
}

#croquisDressPatternTop,
#croquisDressPatternSkirt,
#croquisDressMaterialTop,
#croquisDressMaterialSkirt {
  pointer-events: none;
  stroke: none;
}

#croquisBelt {
  fill: #171519;
  stroke: #151316;
  stroke-width: 1.8;
  display: none;
}

#croquisSparkles {
  display: none;
  fill: rgba(255, 255, 255, 0.82);
  stroke: #151316;
  stroke-width: 0.7;
}

#croquisBow {
  display: none;
  fill: #fff6c7;
  stroke: #151316;
  stroke-width: 1.8;
}

#croquisNecklace {
  display: none;
  fill: none;
  stroke: #bd8a32;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-dasharray: 1 6;
}

.model > .hair,
.model > .head,
.model > .neck,
.model > .shoulders,
.model > .arms,
.model > .body,
.model > .legs,
.model > .shoes {
  display: none;
}

.model::before {
  content: "";
  position: absolute;
  left: 50px;
  bottom: -10px;
  width: 128px;
  height: 22px;
  border-radius: 50%;
  background: rgba(25, 20, 22, 0.22);
  filter: blur(5px);
}

.hair {
  position: absolute;
  top: 8px;
  left: 59px;
  width: 108px;
  height: 118px;
  background:
    linear-gradient(105deg, rgba(255, 255, 255, 0.14), transparent 30%),
    radial-gradient(circle at 26% 20%, rgba(255, 255, 255, 0.18), transparent 28%),
    var(--hair, #3c2d2d);
  z-index: 1;
  box-shadow: inset -12px -12px 18px rgba(0, 0, 0, 0.16);
}

.hair::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 10px;
  width: 68px;
  height: 42px;
  border-radius: 50% 50% 38% 38%;
  background:
    linear-gradient(112deg, rgba(255, 255, 255, 0.22), transparent 42%),
    var(--hair, #3c2d2d);
  transform: rotate(-8deg);
}

.hair::after {
  content: "";
  position: absolute;
  left: 29px;
  top: 15px;
  width: 12px;
  height: 85px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.12);
  transform: rotate(14deg);
}

.hair-bob {
  border-radius: 48px 48px 32px 32px;
}

.hair-curls {
  border-radius: 50%;
  box-shadow:
    -22px 18px 0 -4px var(--hair, #3c2d2d),
    22px 18px 0 -4px var(--hair, #3c2d2d),
    inset -12px -12px 18px rgba(0, 0, 0, 0.16);
}

.hair-braid {
  border-radius: 45px 45px 18px 18px;
}

.hair-braid::after {
  content: "";
  position: absolute;
  right: -18px;
  top: 58px;
  width: 28px;
  height: 128px;
  border-radius: 18px;
  background: repeating-linear-gradient(180deg, var(--hair, #3c2d2d) 0 18px, rgba(255, 255, 255, 0.28) 18px 22px);
}

.hair-braid::before {
  width: 76px;
}

.head {
  position: absolute;
  top: 41px;
  left: 76px;
  width: 74px;
  height: 92px;
  border-radius: 36px 36px 32px 32px;
  background:
    radial-gradient(circle at 34% 28%, rgba(255, 255, 255, 0.22), transparent 21%),
    linear-gradient(100deg, rgba(255, 255, 255, 0.14), transparent 45%, rgba(92, 47, 38, 0.12)),
    var(--skin, #d49a75);
  z-index: 2;
  box-shadow: inset -7px -8px 12px rgba(91, 54, 43, 0.13);
}

.head::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 38px;
  width: 7px;
  height: 14px;
  border-right: 2px solid rgba(76, 50, 48, 0.28);
  border-bottom: 1px solid rgba(76, 50, 48, 0.2);
  border-radius: 0 0 8px 0;
}

.head::after {
  content: "";
  position: absolute;
  left: -7px;
  top: 39px;
  width: 10px;
  height: 18px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 58% 50%, rgba(92, 47, 38, 0.18) 0 3px, transparent 4px),
    var(--skin, #d49a75);
  box-shadow: 78px 0 0 var(--skin, #d49a75);
  z-index: -1;
}

.eye,
.lash,
.blush,
.lips,
.face-sticker {
  position: absolute;
  display: block;
}

.eye {
  top: 36px;
  width: 9px;
  height: 6px;
  border-radius: 50%;
  background: radial-gradient(circle at 64% 35%, #fff 0 1px, #25212b 2px);
}

.eye.left {
  left: 19px;
}

.eye.right {
  right: 19px;
}

.lash {
  top: 31px;
  width: 17px;
  height: 7px;
  border-top: 2px solid #25212b;
  opacity: var(--lashes, 0.55);
}

.lash.left {
  left: 14px;
  transform: rotate(8deg);
}

.lash.right {
  right: 14px;
  transform: rotate(-8deg);
}

.blush {
  top: 54px;
  width: 15px;
  height: 9px;
  border-radius: 50%;
  background: #e9849f;
  opacity: var(--blush, 0.4);
}

.blush.left {
  left: 11px;
}

.blush.right {
  right: 11px;
}

.lips {
  left: 28px;
  bottom: 16px;
  width: 18px;
  height: 8px;
  border-radius: 0 0 12px 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.22), transparent), var(--lip, #b53657);
}

.lips::after {
  content: "";
  position: absolute;
  left: 3px;
  right: 3px;
  top: 3px;
  height: 1px;
  background: rgba(70, 24, 34, 0.32);
}

.face-sticker {
  right: 10px;
  top: 15px;
  color: var(--sticker-color, #c98d24);
  font-size: 0.82rem;
}

.head .eye::after {
  content: "";
  position: absolute;
  left: -2px;
  top: -8px;
  width: 14px;
  height: 5px;
  border-top: 2px solid rgba(48, 36, 35, 0.55);
  border-radius: 50%;
}

.neck {
  position: absolute;
  top: 128px;
  left: 96px;
  width: 34px;
  height: 48px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.08), transparent 45%), var(--skin, #d49a75);
  border-radius: 0 0 12px 12px;
  z-index: 1;
}

.shoulders {
  position: absolute;
  top: 166px;
  left: 45px;
  width: 136px;
  height: 44px;
  border-radius: 50% 50% 18px 18px;
  background:
    radial-gradient(ellipse at 50% 10%, rgba(255, 255, 255, 0.18), transparent 42%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.12), transparent 45%, rgba(0, 0, 0, 0.14)),
    var(--skin, #d49a75);
  box-shadow: inset -10px -12px 16px rgba(75, 45, 40, 0.12);
  z-index: 1;
  clip-path: polygon(8% 44%, 25% 13%, 75% 13%, 92% 44%, 84% 100%, 16% 100%);
}

.shoulders::after {
  content: "";
  position: absolute;
  left: 39px;
  top: 19px;
  width: 58px;
  height: 14px;
  border-top: 1px solid rgba(75, 45, 40, 0.22);
  border-radius: 50%;
}

.arms {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.arm {
  position: absolute;
  top: 189px;
  width: 18px;
  height: 154px;
  border-radius: 14px 14px 12px 12px;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.16), transparent 38%, rgba(255, 255, 255, 0.12)),
    var(--skin, #d49a75);
  box-shadow: inset -5px -12px 12px rgba(72, 42, 36, 0.12);
  transform-origin: top center;
}

.arm::before {
  content: "";
  position: absolute;
  left: 2px;
  right: 2px;
  top: 72px;
  height: 1px;
  background: rgba(76, 45, 40, 0.22);
  box-shadow: 0 2px 6px rgba(76, 45, 40, 0.08);
}

.arm.left {
  left: 42px;
  transform: rotate(10deg);
}

.arm.right {
  right: 42px;
  transform: rotate(-10deg);
}

.hand {
  position: absolute;
  left: -2px;
  bottom: -13px;
  width: 22px;
  height: 23px;
  border-radius: 48% 48% 54% 54%;
  background:
    radial-gradient(circle at 36% 24%, rgba(255, 255, 255, 0.18), transparent 32%),
    var(--skin, #d49a75);
  box-shadow: inset -5px -5px 8px rgba(70, 41, 36, 0.12);
}

.hand::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 14px;
  width: 12px;
  height: 1px;
  background: rgba(75, 45, 40, 0.18);
  box-shadow: 0 4px 0 rgba(75, 45, 40, 0.12);
}

.body {
  position: absolute;
  top: 166px;
  left: 39px;
  width: 148px;
  height: 238px;
  z-index: 4;
}

.body::before {
  content: "";
  position: absolute;
  top: -10px;
  left: 26px;
  width: 96px;
  height: 36px;
  border-radius: 50% 50% 16px 16px;
  background:
    linear-gradient(90deg, rgba(0, 0, 0, 0.08), transparent 50%, rgba(0, 0, 0, 0.1)),
    var(--skin, #d49a75);
  z-index: -1;
}

.dress {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 36% 12%, rgba(255, 255, 255, 0.34), transparent 24%),
    linear-gradient(100deg, rgba(255, 255, 255, 0.14), transparent 32%, rgba(0, 0, 0, 0.18)),
    var(--dress, #c74970);
  overflow: hidden;
  clip-path: polygon(33% 0, 67% 0, 78% 34%, 90% 100%, 10% 100%, 22% 34%);
  box-shadow: inset -16px -28px 28px rgba(36, 20, 25, 0.18), inset 10px 0 20px rgba(255, 255, 255, 0.1);
}

.dress::before {
  content: "";
  position: absolute;
  inset: 10px 18px 0;
  background:
    linear-gradient(90deg, transparent 0 18%, rgba(255, 255, 255, 0.22) 19%, transparent 21% 48%, rgba(0, 0, 0, 0.12) 50%, transparent 53% 78%, rgba(255, 255, 255, 0.18) 80%, transparent 82%),
    linear-gradient(180deg, transparent 0 64%, rgba(255, 255, 255, 0.12));
  opacity: 0.78;
  pointer-events: none;
}

.dress::after {
  content: "";
  position: absolute;
  left: 14%;
  right: 14%;
  bottom: 10px;
  height: 16px;
  border-bottom: 2px solid rgba(255, 255, 255, 0.28);
  border-radius: 50%;
  opacity: 0.76;
}

.top-square {
  clip-path: polygon(27% 0, 73% 0, 79% 34%, 88% 100%, 12% 100%, 21% 34%);
}

.top-heart {
  clip-path: polygon(31% 5%, 43% 0, 50% 10%, 57% 0, 69% 5%, 78% 34%, 90% 100%, 10% 100%, 22% 34%);
}

.top-cape {
  clip-path: polygon(18% 0, 82% 0, 87% 36%, 98% 100%, 2% 100%, 13% 36%);
}

.skirt-pencil {
  border-radius: 36px 36px 12px 12px;
}

.skirt-princess {
  clip-path: polygon(28% 0, 72% 0, 100% 100%, 0 100%);
}

.skirt-wave {
  clip-path: polygon(24% 0, 76% 0, 92% 78%, 78% 100%, 58% 86%, 39% 100%, 18% 86%, 6% 100%);
}

.pattern,
.material {
  position: absolute;
  inset: 0;
}

.pattern.dots {
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.5) 0 4px, transparent 5px);
  background-size: 23px 23px;
}

.pattern.stripes {
  background-image: repeating-linear-gradient(45deg, rgba(255, 255, 255, 0.4) 0 8px, transparent 8px 18px);
}

.pattern.flowers {
  background-image: radial-gradient(circle at 20% 20%, rgba(255, 247, 166, 0.66) 0 4px, transparent 6px), radial-gradient(circle at 70% 55%, rgba(255, 255, 255, 0.56) 0 4px, transparent 5px);
  background-size: 38px 38px;
}

.material.satin {
  background:
    linear-gradient(100deg, transparent 0 33%, rgba(255, 255, 255, 0.42) 43%, transparent 56%),
    linear-gradient(78deg, rgba(255, 255, 255, 0.08), transparent 24%, rgba(0, 0, 0, 0.09));
}

.material.velvet {
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.05) 0 1px, transparent 1px 4px),
    linear-gradient(180deg, rgba(0, 0, 0, 0.05), rgba(0, 0, 0, 0.25));
}

.material.tulle {
  background-image: linear-gradient(90deg, rgba(255, 255, 255, 0.24) 1px, transparent 1px), linear-gradient(0deg, rgba(255, 255, 255, 0.18) 1px, transparent 1px);
  background-size: 12px 12px;
  opacity: 0.82;
}

.belt,
.sparkles,
.bow {
  position: absolute;
  display: none;
  z-index: 2;
}

.belt.on {
  display: block;
  top: 68px;
  left: 28px;
  width: 86px;
  height: 12px;
  border-radius: 8px;
  background: linear-gradient(180deg, #322c31, #0f0e10);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.22);
}

.sparkles.on {
  display: block;
  inset: 8px 12px;
  background-image: radial-gradient(circle, #fff 0 2px, transparent 3px);
  background-size: 20px 22px;
}

.bow.on {
  display: block;
  top: 60px;
  left: 60px;
  width: 22px;
  height: 18px;
}

.bow.on::before,
.bow.on::after {
  content: "";
  position: absolute;
  top: 0;
  width: 14px;
  height: 18px;
  background: #fff6c7;
  border-radius: 50% 10px 50% 10px;
}

.bow.on::before {
  left: -2px;
  transform: rotate(28deg);
}

.bow.on::after {
  right: -2px;
  transform: rotate(-28deg);
}

.sleeve {
  position: absolute;
  top: 15px;
  width: 27px;
  height: 58px;
  border-radius: 15px 15px 12px 12px;
  background:
    linear-gradient(105deg, rgba(255, 255, 255, 0.18), transparent 38%, rgba(0, 0, 0, 0.18)),
    var(--dress, #c74970);
  box-shadow: inset -8px -10px 12px rgba(0, 0, 0, 0.12);
  overflow: visible;
  z-index: 6;
}

.sleeve::after {
  content: none;
}

.sleeve::before {
  content: none;
}

.sleeve.left {
  left: 0;
  transform: rotate(12deg);
}

.sleeve.right {
  right: 0;
  transform: rotate(-12deg);
}

.necklace {
  position: absolute;
  top: 10px;
  left: 53px;
  width: 36px;
  height: 22px;
  border-bottom: 3px dotted #fff6c7;
  border-radius: 0 0 28px 28px;
  display: none;
}

.necklace.on {
  display: block;
}

.legs {
  position: absolute;
  top: 396px;
  left: 84px;
  display: flex;
  gap: 22px;
  z-index: 1;
}

.legs span {
  width: 15px;
  height: 86px;
  border-radius: 10px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.1), transparent 42%), var(--skin, #d49a75);
  clip-path: polygon(12% 0, 88% 0, 78% 100%, 18% 100%);
}

.shoes {
  position: absolute;
  top: 476px;
  left: 72px;
  display: flex;
  gap: 18px;
  z-index: 2;
}

.shoes span {
  width: 34px;
  height: 13px;
  border-radius: 12px 12px 4px 4px;
  background: linear-gradient(180deg, #302b31, #0f0e10);
  position: relative;
}

.model[data-pose="statuesque"] {
  transform: scaleY(1.02);
}

.model[data-pose="statuesque"] .head {
  border-radius: 38px 38px 34px 34px;
}

.model[data-pose="statuesque"] .arm.left {
  transform: rotate(4deg);
}

.model[data-pose="statuesque"] .arm.right {
  transform: rotate(-4deg);
}

.model[data-pose="soft"] .head {
  width: 76px;
  left: 75px;
  border-radius: 39px 39px 34px 34px;
}

.model[data-pose="soft"] .shoulders {
  width: 126px;
  left: 50px;
}

.model[data-pose="runway"] .arm.left {
  transform: rotate(15deg);
}

.model[data-pose="runway"] .arm.right {
  transform: rotate(-5deg);
}

.model[data-pose="runway"] .legs {
  gap: 18px;
}

.shoes span::after {
  content: "";
  position: absolute;
  right: 2px;
  bottom: -8px;
  width: 5px;
  height: 10px;
  border-radius: 2px;
  background: #0f0e10;
  transform: rotate(-7deg);
}

.result-panel {
  padding: 14px;
  border-top: 1px solid var(--line);
}

.score-grid {
  display: grid;
  gap: 8px;
}

.score-row {
  display: grid;
  grid-template-columns: 110px 1fr 36px;
  gap: 8px;
  align-items: center;
  font-size: 0.86rem;
}

.bar {
  height: 8px;
  border-radius: 99px;
  background: #eadfd9;
  overflow: hidden;
}

.bar span {
  display: block;
  height: 100%;
  background: var(--teal);
}

.tabs {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-bottom: 1px solid var(--line);
}

.tab {
  min-height: 48px;
  padding: 0 6px;
  color: var(--muted);
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  font-size: 0.82rem;
  font-weight: 900;
}

.tab.active {
  color: var(--ink);
  background: #f7f1ea;
  box-shadow: inset 0 -3px 0 var(--rose);
}

.panel {
  display: none;
  padding: 14px;
}

.panel.active {
  display: block;
}

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 14px;
}

.control-block {
  margin-bottom: 14px;
}

.control-block label,
.text-field {
  display: block;
  margin-bottom: 7px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 900;
}

.chips,
.swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.chip {
  min-height: 40px;
  color: var(--ink);
  background: linear-gradient(180deg, #f8f3ef, #ede3dc);
  border-color: rgba(33, 30, 34, 0.08);
  box-shadow: none;
}

.chip.active {
  color: #fff;
  background: linear-gradient(180deg, #27908a, #126c68);
}

.challenge-strip {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  margin: 0 0 14px;
  padding: 11px;
  border: 1px solid rgba(169, 52, 87, 0.22);
  border-radius: 8px;
  background:
    linear-gradient(120deg, rgba(169, 52, 87, 0.12), rgba(22, 125, 120, 0.1)),
    #fffdf9;
}

.challenge-strip strong,
.challenge-strip span,
.challenge-card span,
.challenge-card strong,
.challenge-card small,
.vote-card strong,
.vote-card span,
.vote-card b,
.bank-card strong,
.bank-card span {
  display: block;
}

.challenge-strip span,
.challenge-card small,
.vote-card span,
.bank-card span {
  color: var(--muted);
  font-size: 0.78rem;
}

.challenge-strip b {
  padding: 6px 8px;
  border-radius: 99px;
  color: #fff;
  background: var(--rose);
  font-size: 0.75rem;
}

.look-deck {
  display: grid;
  grid-template-columns: repeat(5, minmax(82px, 1fr));
  gap: 8px;
  margin: 0 0 14px;
  overflow-x: auto;
  padding-bottom: 2px;
}

.look-preset {
  display: grid;
  gap: 6px;
  min-width: 82px;
  min-height: 124px;
  padding: 6px;
  color: var(--ink);
  background: linear-gradient(180deg, #fffdf9, #f1e7df);
  border: 1px solid var(--line);
  box-shadow: none;
}

.look-preset img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 8px;
  object-fit: cover;
  object-position: center 28%;
}

.look-preset span {
  font-size: 0.72rem;
  line-height: 1.1;
  text-align: center;
}

.look-preset.active {
  color: #fff;
  background: linear-gradient(145deg, #a93457, #62558f);
}

.season-panel,
.mission-card {
  display: grid;
  gap: 8px;
  margin-bottom: 10px;
  padding: 11px;
  border: 1px solid rgba(98, 85, 143, 0.2);
  border-radius: 8px;
  background:
    radial-gradient(circle at 12% 12%, rgba(244, 212, 87, 0.18), transparent 6rem),
    linear-gradient(180deg, #fffdf9, #f3ebf8);
}

.season-panel strong,
.season-panel span,
.mission-card strong,
.mission-card span {
  display: block;
}

.season-panel span,
.mission-card span {
  color: var(--muted);
  font-size: 0.78rem;
}

.season-meter {
  height: 9px;
  border-radius: 99px;
  overflow: hidden;
  background: rgba(98, 85, 143, 0.18);
}

.season-meter span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, #a93457, #f4d457);
}

.mission-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.mission-card {
  grid-template-columns: 1fr auto;
  align-items: center;
  margin: 0;
}

.mission-card.done {
  border-color: rgba(22, 125, 120, 0.34);
}

.mission-card button {
  min-height: 36px;
  color: #fff;
  background: linear-gradient(180deg, #27908a, #126c68);
  box-shadow: none;
}

.mission-card button:disabled {
  color: rgba(33, 30, 34, 0.5);
  background: #e8ddd6;
}

.challenge-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.challenge-card,
.vote-card {
  display: grid;
  gap: 4px;
  min-height: 88px;
  padding: 10px;
  color: var(--ink);
  text-align: left;
  background: linear-gradient(180deg, #fffdf9, #f1e7df);
  border: 1px solid var(--line);
  box-shadow: none;
}

.challenge-card {
  position: relative;
  min-height: 154px;
  grid-template-columns: 72px 1fr;
  align-items: end;
  overflow: hidden;
}

.challenge-card img {
  grid-row: 1 / span 3;
  width: 72px;
  height: 104px;
  border-radius: 8px;
  object-fit: cover;
  object-position: center 28%;
  box-shadow: 0 10px 24px rgba(32, 12, 42, 0.18);
}

.challenge-card.active {
  color: #fff;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.24), transparent 7rem),
    linear-gradient(145deg, #a93457, #62558f);
}

.challenge-card.active small {
  color: rgba(255, 255, 255, 0.78);
}

.bank-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  margin: 10px 0 12px;
  padding: 11px;
  border-radius: 8px;
  background:
    radial-gradient(circle at top left, rgba(189, 138, 50, 0.24), transparent 8rem),
    linear-gradient(180deg, #fffdf9, #eadfd7);
  border: 1px solid var(--line);
}

.bank-card button {
  color: #fff;
  background: linear-gradient(180deg, #bd8a32, #8d6120);
}

.vote-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 12px;
}

.vote-card {
  position: relative;
  min-height: 76px;
}

.vote-card b {
  position: absolute;
  right: 10px;
  bottom: 8px;
  color: var(--rose);
}

.swatch {
  width: 40px;
  height: 40px;
  min-height: 40px;
  border: 3px solid #fff;
  border-radius: 50%;
  padding: 0;
  box-shadow: 0 0 0 1px var(--line), inset 0 4px 8px rgba(255, 255, 255, 0.28), 0 8px 18px rgba(37, 33, 43, 0.12);
}

.swatch.active {
  box-shadow: 0 0 0 3px var(--ink);
}

input[type="range"] {
  width: 100%;
  accent-color: var(--rose);
}

.quiet {
  color: var(--muted);
  font-size: 0.9rem;
}

.shop-list,
.wardrobe,
.album {
  display: grid;
  gap: 8px;
}

.shop-item,
.look-card,
.client-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, #fffdf9, #f6eee8);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.shop-item strong,
.look-card strong,
.client-card strong {
  display: block;
  font-size: 0.9rem;
}

.shop-item span,
.look-card span,
.client-card span {
  color: var(--muted);
  font-size: 0.8rem;
}

.shop-item button,
.look-card button {
  color: #fff;
  background: var(--violet);
  box-shadow: none;
}

.mini-games {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 12px 0;
}

.text-field input {
  width: 100%;
  min-height: 44px;
  margin-top: 6px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
}

.brand-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 12px 0;
}

.brand-stats div {
  padding: 10px;
  border-radius: 8px;
  background: linear-gradient(180deg, #e3f1ed, #cfe5df);
  text-align: center;
}

.brand-stats strong,
.brand-stats span {
  display: block;
}

.brand-stats span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 900;
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 18px;
  z-index: 10;
  width: min(420px, calc(100% - 28px));
  padding: 12px 14px;
  border-radius: 8px;
  color: #fff;
  background: rgba(37, 33, 43, 0.94);
  box-shadow: var(--shadow);
  opacity: 0;
  transform: translate(-50%, 18px);
  pointer-events: none;
  transition: 0.22s ease;
}

.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

@media (max-width: 820px) {
  .app-shell {
    padding: 10px;
  }

  .workspace {
    grid-template-columns: 1fr;
  }

  .runway {
    min-height: 620px;
  }

  .model-wrap {
    transform: scale(0.86);
    transform-origin: bottom center;
  }

  .tabs {
    position: sticky;
    top: 0;
    z-index: 5;
    background: rgba(255, 255, 255, 0.95);
  }

  .tab {
    font-size: 0.72rem;
  }

  .mini-games {
    grid-template-columns: 1fr;
  }

  .challenge-list,
  .vote-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 420px) {
  .topbar {
    align-items: flex-start;
  }

  .wallet {
    font-size: 0.84rem;
  }

  .runway {
    min-height: 560px;
  }

  .model-wrap {
    transform: scale(0.7);
  }
}

body[data-view="beaute"] .model-wrap {
  position: absolute;
  inset: 112px 0 0;
  width: 100%;
  height: auto;
  transform: none;
  display: block;
}

body[data-view="beaute"] .model {
  width: 100%;
  height: 100%;
}

body[data-view="beaute"] .photo-avatar {
  inset: 0;
  border-radius: 0 0 30px 30px;
}

body[data-view="beaute"] .photo-avatar picture img {
  object-position: center 36%;
}

@media (max-width: 820px) {
  body[data-view="beaute"] .model-wrap {
    top: 112px;
    transform: none;
  }
}

@media (max-width: 420px) {
  body[data-view="beaute"] .model-wrap {
    top: 104px;
    transform: none;
  }
}

.model-chip {
  min-height: 112px;
  padding: 6px;
  gap: 6px;
}

.model-chip img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 8px;
  object-fit: cover;
  object-position: center 28%;
}

.model-chip span {
  font-size: 0.74rem;
}

.photo-hair-tint {
  inset: 0;
  z-index: 21;
  opacity: var(--hair-tint-strength, 0.34);
  background:
    radial-gradient(ellipse at var(--hair-left-x, 24%) 45%, var(--photo-hair) 0 23%, transparent 47%),
    radial-gradient(ellipse at var(--hair-right-x, 76%) 45%, var(--photo-hair) 0 23%, transparent 47%),
    radial-gradient(ellipse at 50% var(--hair-top-y, 14%), var(--photo-hair) 0 21%, transparent 36%),
    linear-gradient(90deg, transparent 14%, var(--photo-hair) 22% 35%, transparent 48% 52%, var(--photo-hair) 65% 78%, transparent 86%);
  mix-blend-mode: color;
  filter: saturate(1.28) contrast(1.08);
  pointer-events: none;
}

.photo-eye-tint {
  inset: 0;
  z-index: 25;
  opacity: 0.96;
  background:
    radial-gradient(circle at var(--eye-left-x, 44%) var(--eye-y, 26%), rgba(255, 255, 255, 0.96) 0 0.24%, var(--photo-eye) 0.3% 0.82%, rgba(18, 12, 18, 0.82) 0.86% 1.08%, transparent 1.14%),
    radial-gradient(circle at var(--eye-right-x, 56%) var(--eye-y, 26%), rgba(255, 255, 255, 0.96) 0 0.24%, var(--photo-eye) 0.3% 0.82%, rgba(18, 12, 18, 0.82) 0.86% 1.08%, transparent 1.14%);
  filter: saturate(1.55) brightness(1.05);
  mix-blend-mode: normal;
  pointer-events: none;
}

.photo-avatar[data-variant-mode="asset"] .photo-hair-tint,
.photo-avatar[data-variant-mode="asset"] .photo-eye-tint {
  display: none;
}

.photo-accessories {
  inset: 0;
  z-index: 26;
  pointer-events: none;
}

.photo-avatar.has-sparkles .photo-accessories {
  background-image:
    radial-gradient(circle, rgba(255, 255, 255, 0.92) 0 2px, transparent 3px),
    radial-gradient(circle, rgba(247, 219, 111, 0.88) 0 2px, transparent 3px);
  background-size: 38px 44px, 54px 48px;
  background-position: 18px 210px, 44px 260px;
}

.photo-avatar.has-necklace .photo-accessories::before {
  content: "";
  position: absolute;
  left: 37%;
  top: 65%;
  width: 26%;
  height: 9%;
  border-bottom: 4px dotted rgba(247, 219, 111, 0.95);
  border-radius: 0 0 50% 50%;
  filter: drop-shadow(0 2px 4px rgba(40, 12, 50, 0.32));
}

.photo-avatar.has-bow .photo-accessories::after {
  content: "";
  position: absolute;
  left: 47%;
  top: 72%;
  width: 34px;
  height: 22px;
  background: #fff3bd;
  clip-path: polygon(0 10%, 40% 50%, 0 90%, 50% 70%, 100% 90%, 60% 50%, 100% 10%, 50% 30%);
  filter: drop-shadow(0 4px 8px rgba(44, 18, 48, 0.28));
}

.photo-avatar.has-belt .photo-texture {
  box-shadow: inset 0 -28px 0 rgba(28, 18, 28, 0.46);
}

body[data-view="defile"] .photo-hair-tint,
body[data-view="defile"] .photo-eye-tint {
  opacity: 0.12;
}

body[data-view="beaute"] .photo-hair-tint {
  opacity: var(--hair-tint-strength, 0.42);
}

body[data-view="beaute"] .photo-eye-tint {
  opacity: 1;
}

body[data-view="beaute"] .photo-accessories {
  display: none;
}

body[data-view="beaute"] .app-shell {
  padding-top: 8px;
}

body[data-view="beaute"] .topbar {
  display: none;
}

body[data-view="beaute"] .stage {
  overflow: hidden;
}

@media (max-width: 820px) {
  body[data-view="beaute"] .runway {
    min-height: 690px;
  }

  body[data-view="beaute"] .model-wrap {
    transform: translateY(158px) scale(2.18);
    transform-origin: center 22%;
  }

  body[data-view="beaute"] .beauty-tray {
    left: 8%;
    right: 8%;
    bottom: 16px;
    gap: 10px;
  }
}

@media (max-width: 420px) {
  body[data-view="beaute"] .app-shell {
    padding: 6px;
  }

  body[data-view="beaute"] .runway {
    min-height: 650px;
  }

  body[data-view="beaute"] .glam-banner {
    height: 104px;
  }

  body[data-view="beaute"] .model-wrap {
    transform: translateY(152px) scale(2.05);
    transform-origin: center 22%;
  }

  body[data-view="beaute"] .beauty-tray {
    left: 6%;
    right: 6%;
    bottom: 14px;
    gap: 8px;
  }
}

.model {
  width: 340px;
  height: 640px;
}

.photo-avatar {
  position: absolute;
  inset: 0;
  z-index: 20;
  overflow: hidden;
  border-radius: 30px;
  background:
    radial-gradient(circle at 50% 24%, rgba(255, 230, 156, 0.24), transparent 13rem),
    linear-gradient(180deg, #8a57c4, #271133);
  box-shadow: 0 24px 52px rgba(28, 8, 46, 0.28);
  --photo-dress: #b88cff;
  --photo-hair: #3c2d2d;
  --photo-lip: #b53657;
}

.photo-avatar picture,
.photo-avatar img,
.photo-avatar span {
  position: absolute;
}

.photo-avatar picture,
.photo-avatar picture img {
  inset: 0;
  width: 100%;
  height: 100%;
}

.photo-avatar picture img {
  object-fit: cover;
  object-position: center 35%;
  filter: saturate(1.08) contrast(1.04);
}

.photo-garment {
  left: 13%;
  right: 13%;
  bottom: -1%;
  width: 74%;
  height: 43%;
  object-fit: contain;
  object-position: center bottom;
  opacity: 0.38;
  filter:
    drop-shadow(0 -8px 12px rgba(24, 10, 42, 0.18))
    saturate(1.12);
  mix-blend-mode: soft-light;
  pointer-events: none;
}

.photo-texture {
  left: 17%;
  right: 17%;
  bottom: 0;
  height: 34%;
  z-index: 23;
  border-radius: 38% 38% 0 0;
  background:
    linear-gradient(103deg, rgba(255, 255, 255, 0.2), transparent 42%, rgba(28, 5, 44, 0.28)),
    var(--photo-dress);
  opacity: 0.28;
  mix-blend-mode: color;
  clip-path: polygon(12% 0, 88% 0, 100% 100%, 0 100%);
  pointer-events: none;
}

.photo-avatar[data-pattern="dots"] .photo-texture {
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.72) 0 4px, transparent 5px),
    linear-gradient(103deg, rgba(255, 255, 255, 0.18), transparent 44%, rgba(28, 5, 44, 0.28)),
    var(--photo-dress);
  background-size: 24px 24px, auto, auto;
}

.photo-avatar[data-pattern="stripes"] .photo-texture {
  background:
    repeating-linear-gradient(42deg, rgba(255, 255, 255, 0.52) 0 7px, transparent 7px 18px),
    linear-gradient(103deg, rgba(255, 255, 255, 0.18), transparent 44%, rgba(28, 5, 44, 0.28)),
    var(--photo-dress);
}

.photo-avatar[data-pattern="flowers"] .photo-texture {
  background:
    radial-gradient(circle at 22% 24%, rgba(255, 239, 147, 0.78) 0 6px, transparent 7px),
    radial-gradient(circle at 72% 62%, rgba(255, 255, 255, 0.7) 0 5px, transparent 6px),
    linear-gradient(103deg, rgba(255, 255, 255, 0.18), transparent 44%, rgba(28, 5, 44, 0.28)),
    var(--photo-dress);
  background-size: 42px 42px, 38px 38px, auto, auto;
}

.photo-avatar[data-material="velvet"] .photo-texture {
  opacity: 0.36;
  mix-blend-mode: multiply;
  filter: contrast(1.18) saturate(0.9);
}

.photo-avatar[data-material="tulle"] .photo-texture {
  opacity: 0.22;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.34) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, 0.28) 1px, transparent 1px),
    var(--photo-dress);
  background-size: 13px 13px, 13px 13px, auto;
}

.photo-flashes {
  inset: 0;
  z-index: 24;
  opacity: 0;
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.9), transparent 5rem),
    radial-gradient(circle at 78% 24%, rgba(255, 245, 208, 0.76), transparent 4rem);
  pointer-events: none;
}

.model-wrap.walk .photo-avatar {
  animation: photoWalk 1.5s ease both;
}

.model-wrap.walk .photo-flashes {
  animation: cameraFlash 1.3s ease 0.2s both;
}

@keyframes photoWalk {
  0% { transform: translateX(-42px) scale(0.94); filter: brightness(0.94); }
  48% { transform: translateX(0) scale(1.03); filter: brightness(1.1); }
  100% { transform: translateX(34px) scale(1); filter: brightness(1); }
}

@keyframes cameraFlash {
  0%, 24%, 100% { opacity: 0; }
  12% { opacity: 0.75; }
  38% { opacity: 0.48; }
}

.model > .editorial-avatar,
.model > .croquis,
.model > .hair,
.model > .head,
.model > .neck,
.model > .shoulders,
.model > .arms,
.model > .body,
.model > .legs,
.model > .shoes {
  display: none;
}

body[data-view="beaute"] .model-wrap {
  transform: translateY(116px) scale(1.08);
}

body[data-view="beaute"] .model {
  width: min(490px, 92vw);
  height: 690px;
}

body[data-view="beaute"] .photo-avatar {
  border-radius: 0 0 30px 30px;
  box-shadow: none;
}

body[data-view="beaute"] .photo-avatar picture img {
  object-position: center 32%;
}

body[data-view="beaute"] .photo-garment,
body[data-view="beaute"] .photo-texture {
  opacity: 0;
}

body[data-view="atelier"] .photo-avatar picture img,
body[data-view="boutique"] .photo-avatar picture img,
body[data-view="marque"] .photo-avatar picture img {
  object-position: center 34%;
}

body[data-view="defile"] .runway {
  background:
    radial-gradient(circle at 20% 18%, rgba(255, 255, 255, 0.34), transparent 7rem),
    radial-gradient(circle at 82% 22%, rgba(255, 239, 184, 0.28), transparent 8rem),
    linear-gradient(180deg, #201121 0%, #5b247d 44%, #160d1b 100%);
}

body[data-view="defile"] .photo-avatar {
  border-radius: 22px;
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.36),
    0 0 0 1px rgba(255, 255, 255, 0.2);
}

.result-panel {
  position: relative;
  margin: -118px 18px 18px;
  z-index: 30;
  border: 1px solid rgba(255, 255, 255, 0.62);
  border-radius: 18px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(38, 12, 51, 0.88), rgba(127, 55, 157, 0.78)),
    rgba(33, 16, 48, 0.78);
  box-shadow: 0 22px 60px rgba(40, 13, 54, 0.3);
  backdrop-filter: blur(18px);
}

.result-panel h2 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2rem, 7vw, 4.2rem);
  line-height: 0.92;
}

.result-panel h2::before {
  content: none;
}

.score-stars {
  margin: -2px 0 8px;
  color: #f7db6f;
  font-size: 1.25rem;
  letter-spacing: 0.08em;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.22);
}

.result-panel p {
  font-weight: 800;
}

.score-row {
  color: rgba(255, 255, 255, 0.94);
}

.bar {
  background: rgba(255, 255, 255, 0.24);
}

.bar span {
  background: linear-gradient(90deg, #f4d457, #fff1a8);
}

.beauty-thumb {
  background-image: url("assets/editorial/beauty-face-thumb-v1.webp");
  background-size: cover;
  background-position: center;
}

.beauty-thumb::before,
.beauty-thumb::after {
  display: none;
}

.beauty-thumb.face.two {
  filter: hue-rotate(18deg) saturate(0.82) brightness(0.92);
}

.beauty-thumb.face.three {
  filter: hue-rotate(-16deg) saturate(1.12);
}

.beauty-thumb.face.four {
  filter: sepia(0.18) saturate(0.9) brightness(0.9);
}

.beauty-thumb.hair {
  background-image: url("assets/editorial/beauty-bust-thumb-v1.webp");
  background-position: center 35%;
}

.beauty-thumb.hair.one {
  filter: hue-rotate(20deg) saturate(0.82) brightness(1.05);
}

.beauty-thumb.hair.two {
  filter: hue-rotate(-26deg) saturate(1.25);
}

.beauty-thumb.hair.three {
  filter: saturate(0.72) contrast(1.08);
}

.beauty-thumb.hair.four {
  filter: contrast(1.08) brightness(0.8);
}

@media (max-width: 820px) {
  .model {
    width: min(360px, 92vw);
    height: 640px;
  }

  .look-deck {
    grid-template-columns: repeat(5, 96px);
  }

  .mission-list {
    grid-template-columns: 1fr;
  }

  body[data-view="beaute"] .model-wrap {
    transform: translateY(104px) scale(1);
  }

  body[data-view="beaute"] .model {
    height: 660px;
  }
}

@media (max-width: 420px) {
  body[data-view="beaute"] .runway {
    min-height: 650px;
  }

  body[data-view="beaute"] .model-wrap {
    transform: translateY(100px) scale(0.98);
  }

  body[data-view="beaute"] .model {
    width: 100%;
    height: 650px;
  }
}

body[data-view="beaute"] .model-wrap {
  position: absolute;
  inset: 112px 0 0;
  width: 100%;
  height: auto;
  transform: none;
  display: block;
}

body[data-view="beaute"] .model {
  width: 100%;
  height: 100%;
}

body[data-view="beaute"] .photo-avatar {
  inset: 0;
  border-radius: 0 0 30px 30px;
}

body[data-view="beaute"] .photo-avatar picture img {
  object-position: center 36%;
}

@media (max-width: 820px) {
  body[data-view="beaute"] .model-wrap {
    top: 112px;
    transform: none;
  }
}

@media (max-width: 420px) {
  body[data-view="beaute"] .model-wrap {
    top: 104px;
    transform: none;
  }
}
