.mobile-video-review-dialog {
  position: fixed;
  inset: 0;
  width: 100vw;
  max-width: none;
  height: 100dvh;
  max-height: none;
  margin: 0;
  border: 0;
  outline: 0;
  padding: 0;
  background: transparent;
}

.mobile-video-review-dialog::backdrop {
  background: #030813;
}

.mobile-video-review-shell {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 4px;
  width: 100%;
  min-height: 100dvh;
  max-height: 100dvh;
  padding: 24px 14px 9px;
  overflow: hidden;
  color: #f8fbff;
  background:
    radial-gradient(circle at 74% 7%, rgba(38, 104, 255, .24), rgba(38, 104, 255, 0) 28%),
    radial-gradient(circle at 18% 56%, rgba(0, 217, 255, .12), rgba(0, 217, 255, 0) 35%),
    linear-gradient(180deg, #020713 0%, #061529 48%, #030916 100%);
}

.mobile-video-review-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 79% 18%, rgba(73, 174, 255, .5) 0 1px, transparent 2px),
    radial-gradient(circle at 36% 22%, rgba(118, 236, 255, .45) 0 1px, transparent 2px);
  background-size: auto, auto;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, .82), rgba(0, 0, 0, .18));
}

.mobile-video-review-shell > * {
  position: relative;
  z-index: 1;
}

.mobile-review-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 30px;
}

.mobile-review-bell {
  position: relative;
  width: 34px;
  height: 34px;
  border: 0;
  background: transparent;
}

.mobile-review-bell::before {
  content: "";
  position: absolute;
  inset: 5px 8px 6px;
  border: 2px solid #fff;
  border-top-left-radius: 13px;
  border-top-right-radius: 13px;
  border-bottom: 0;
  box-shadow: 0 12px 0 -8px #fff;
}

.mobile-review-bell::after {
  content: "";
  position: absolute;
  top: 2px;
  right: 4px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #ff334b;
}

.mobile-review-title {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 34px;
  align-items: center;
  min-height: 40px;
}

.mobile-review-back {
  display: grid;
  place-items: center;
  width: 30px;
  height: 42px;
  color: #fff;
  border: 0;
  background: transparent;
  font-size: 44px;
  font-weight: 700;
  line-height: 1;
}

.mobile-review-title div {
  display: grid;
  justify-items: center;
  gap: 1px;
  min-width: 0;
  transform: none;
}

.mobile-review-title h1 {
  margin: 0;
  color: #fff;
  font-size: 17px;
  line-height: 1.15;
  letter-spacing: 0;
}

.mobile-review-title p {
  margin: 0;
  color: rgba(233, 240, 255, .76);
  font-size: 11px;
  font-weight: 820;
}

.mobile-review-player {
  position: relative;
  display: grid;
  justify-items: center;
  min-height: 325px;
  margin-top: 0;
}

.mobile-review-poster {
  width: 258px;
  height: 325px;
  border-radius: 15px;
  object-fit: cover;
  box-shadow: 0 24px 70px rgba(0, 0, 0, .42);
}

.mobile-video-review-shell.is-fullscreen-preview .mobile-review-player {
  min-height: 420px;
}

.mobile-video-review-shell.is-fullscreen-preview .mobile-review-poster {
  width: min(340px, 82vw);
  height: min(560px, 58dvh);
}

.mobile-review-social {
  position: absolute;
  top: 68px;
  right: 1px;
  display: grid;
  justify-items: center;
  gap: 4px;
  width: 52px;
}

.mobile-review-social button,
.mobile-review-social span {
  display: grid;
  justify-items: center;
  gap: 4px;
  color: #fff;
}

.mobile-review-ai {
  position: relative;
  width: 52px;
  height: 54px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: transparent;
  filter: drop-shadow(0 0 18px rgba(54, 145, 255, .36));
}

.mobile-review-ai img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.mobile-review-social span {
  width: 44px;
  min-height: 40px;
  border-radius: 13px;
  background: rgba(9, 19, 36, .28);
}

.mobile-review-social span img {
  display: grid;
  place-items: center;
  width: 25px;
  height: 24px;
  object-fit: contain;
  filter: drop-shadow(0 3px 9px rgba(0, 0, 0, .28));
}

.mobile-review-social b {
  color: rgba(250, 253, 255, .93);
  font-size: 11px;
  font-weight: 850;
}

.mobile-review-progress {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: 30px auto minmax(0, 1fr) 30px;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  margin-top: 0;
  padding: 0 10px;
  border: 1px solid rgba(130, 159, 215, .32);
  border-radius: 11px;
  background: rgba(16, 29, 52, .86);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
  backdrop-filter: blur(16px);
}

.mobile-review-progress button {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  color: #fff;
  border: 0;
  background: transparent;
  font-size: 18px;
}

.mobile-review-progress button [data-icon] {
  width: 19px;
  height: 19px;
}

.mobile-review-progress button.is-paused [data-icon] {
  position: relative;
  font-size: 0;
}

.mobile-review-progress button.is-paused [data-icon] .aiv-svg {
  display: none;
}

.mobile-review-progress button.is-paused [data-icon]::before,
.mobile-review-progress button.is-paused [data-icon]::after {
  content: "";
  position: absolute;
  top: 3px;
  bottom: 3px;
  width: 4px;
  border-radius: 2px;
  background: currentColor;
}

.mobile-review-progress button.is-paused [data-icon]::before {
  left: 5px;
}

.mobile-review-progress button.is-paused [data-icon]::after {
  right: 5px;
}

.mobile-review-progress .mobile-review-fullscreen {
  position: relative;
  font-size: 0;
}

.mobile-review-progress .mobile-review-fullscreen::before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background:
    linear-gradient(currentColor, currentColor) left top / 8px 2px no-repeat,
    linear-gradient(currentColor, currentColor) left top / 2px 8px no-repeat,
    linear-gradient(currentColor, currentColor) right top / 8px 2px no-repeat,
    linear-gradient(currentColor, currentColor) right top / 2px 8px no-repeat,
    linear-gradient(currentColor, currentColor) left bottom / 8px 2px no-repeat,
    linear-gradient(currentColor, currentColor) left bottom / 2px 8px no-repeat,
    linear-gradient(currentColor, currentColor) right bottom / 8px 2px no-repeat,
    linear-gradient(currentColor, currentColor) right bottom / 2px 8px no-repeat;
}

.mobile-review-progress span {
  color: rgba(235, 244, 255, .78);
  font-size: 11px;
  font-weight: 850;
  white-space: nowrap;
}

.mobile-review-progress span b {
  color: #fff;
}

.mobile-review-progress i {
  position: relative;
  display: block;
  height: 4px;
  border-radius: 999px;
  background: rgba(197, 214, 237, .28);
}

.mobile-review-progress i::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 52%;
  border-radius: inherit;
  background: linear-gradient(90deg, #39a9ff, #804cff);
}

.mobile-review-progress em {
  position: absolute;
  top: 50%;
  left: 52%;
  width: 16px;
  height: 16px;
  border: 4px solid #6c5cff;
  border-radius: 50%;
  background: #fff;
  transform: translate(-50%, -50%);
}

.mobile-review-meta,
.mobile-review-editor {
  border: 1px solid rgba(119, 149, 204, .28);
  background: rgba(13, 27, 49, .82);
  box-shadow: 0 18px 40px rgba(0, 0, 0, .22), inset 0 1px 0 rgba(255, 255, 255, .07);
  backdrop-filter: blur(18px);
}

.mobile-review-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 76px;
  gap: 8px;
  min-height: 82px;
  padding: 8px 10px;
  border-radius: 13px;
}

.mobile-review-meta dl {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 4px 8px;
  margin: 0;
  min-width: 0;
}

.mobile-review-meta dt,
.mobile-review-meta dd {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  font-size: 11px;
  font-weight: 780;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mobile-review-meta dt {
  color: rgba(203, 218, 243, .78);
}

.mobile-review-meta dd {
  color: rgba(250, 253, 255, .96);
}

.mobile-review-meta dd span {
  margin-right: 8px;
  color: #40caff;
}

.mobile-review-meta button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  align-self: end;
  height: 28px;
  color: rgba(239, 247, 255, .9);
  border: 1px solid rgba(138, 169, 221, .35);
  border-radius: 9px;
  background: rgba(255, 255, 255, .08);
  font-size: 11px;
  font-weight: 900;
}

.mobile-review-meta button i {
  width: 14px;
  height: 14px;
  color: rgba(221, 241, 255, .96);
}

.mobile-review-editor {
  display: grid;
  gap: 5px;
  min-height: 240px;
  padding: 0 9px 9px;
  border-radius: 13px;
}

.mobile-review-editor nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0 -9px;
  border-bottom: 1px solid rgba(123, 148, 199, .2);
}

.mobile-review-editor nav button {
  position: relative;
  height: 32px;
  color: rgba(226, 236, 255, .58);
  border: 0;
  background: transparent;
  font-size: 12.5px;
  font-weight: 950;
}

.mobile-review-editor nav button.active {
  color: #fff;
}

.mobile-review-editor nav button.active::after {
  content: "";
  position: absolute;
  right: 18px;
  bottom: 0;
  left: 18px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, #764cff, #24c7ff);
}

.mobile-review-editor label {
  position: relative;
  display: grid;
  gap: 5px;
  min-width: 0;
  color: rgba(235, 244, 255, .88);
  font-size: 12.5px;
  font-weight: 900;
}

.mobile-review-editor textarea {
  box-sizing: border-box;
  width: 100%;
  height: 38px;
  resize: none;
  color: rgba(247, 251, 255, .9);
  border: 1px solid rgba(119, 149, 204, .25);
  border-radius: 10px;
  padding: 9px 52px 9px 10px;
  background: rgba(8, 18, 34, .74);
  font: inherit;
  font-weight: 760;
}

.mobile-review-editor label small {
  position: absolute;
  right: 12px;
  bottom: 10px;
  color: rgba(224, 234, 255, .52);
  font-size: 10.5px;
  font-weight: 850;
}

.mobile-review-suggestions {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.mobile-review-suggestions > span {
  color: rgba(239, 247, 255, .9);
  font-size: 12.5px;
  font-weight: 900;
}

.mobile-review-suggestions article {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) 46px;
  align-items: center;
  gap: 6px;
  min-height: 25px;
  padding: 2px 6px;
  border: 1px solid rgba(119, 149, 204, .22);
  border-radius: 8px;
  background: rgba(255, 255, 255, .035);
}

.mobile-review-suggestions i {
  width: 15px;
  height: 15px;
  color: #48d4ff;
  font-size: 15px;
  font-style: normal;
}

.mobile-review-suggestions p {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  color: rgba(238, 246, 255, .82);
  font-size: 11px;
  font-weight: 820;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mobile-review-suggestions button {
  height: 22px;
  color: #61cfff;
  border: 1px solid rgba(61, 194, 255, .64);
  border-radius: 8px;
  background: rgba(36, 128, 255, .08);
  font-size: 11px;
  font-weight: 950;
}

.mobile-review-actions {
  display: grid;
  grid-template-columns: minmax(0, .86fr) minmax(0, .92fr) minmax(0, 1.5fr);
  gap: 8px;
  margin-top: auto;
}

.mobile-review-actions button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 0;
  height: 46px;
  border-radius: 12px;
  font-size: 12.5px;
  font-weight: 950;
}

.mobile-review-actions button i {
  width: 15px;
  height: 15px;
  flex: 0 0 auto;
}

.mobile-review-outline {
  color: rgba(233, 242, 255, .9);
  border: 1px solid rgba(141, 170, 222, .34);
  background: rgba(255, 255, 255, .08);
}

.mobile-review-primary {
  color: #fff;
  border: 0;
  background: linear-gradient(100deg, #21aaff 0%, #3e6dff 52%, #982dff 100%);
  box-shadow: 0 18px 36px rgba(59, 104, 255, .36), inset 0 1px 0 rgba(255, 255, 255, .25);
}

.mobile-review-empty {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;
  min-height: 60vh;
  text-align: center;
}

.mobile-review-empty strong {
  color: #fff;
  font-size: 24px;
}

.mobile-review-empty p {
  margin: 0;
  color: rgba(226, 236, 255, .7);
  font-weight: 850;
}

.mobile-review-empty button {
  width: 160px;
  height: 46px;
  color: #fff;
  border: 0;
  border-radius: 12px;
  background: linear-gradient(90deg, #2aa8ff, #7a3dff);
  font-weight: 950;
}

body.mobile-video-review-mode {
  overflow: hidden;
}

body.mobile-video-review-mode .mobile-workbench,
body.mobile-video-review-mode .mobile-scan-confirm {
  display: none !important;
}

@media (max-height: 860px) {
  .mobile-review-player {
    min-height: 321px;
  }

  .mobile-review-poster {
    height: 321px;
  }
}

@media (min-height: 880px) {
  .mobile-review-player {
    min-height: 354px;
  }

  .mobile-review-poster {
    width: 286px;
    height: 354px;
  }

  .mobile-review-social {
    top: 74px;
  }
}
