/* Final visual polish for FaceScore result and diagnosis surfaces. */
.fs,
.fs-test {
  --fs-aurora: linear-gradient(90deg, #93c5fd 0%, #c4b5fd 48%, #f0a7d8 100%);
  --fs-aurora-soft: linear-gradient(135deg, rgba(147,197,253,.20) 0%, rgba(196,181,253,.24) 48%, rgba(240,167,216,.20) 100%);
  --grad-primary: var(--fs-aurora);
  --accent: #7c7eea;
}

@media (max-width: 640px) {
  .fs.fs-result-page .result-distribution {
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .curve-wrap {
    box-sizing: border-box !important;
    width: min(100%, 318px) !important;
    max-width: calc(100vw - 4.5rem) !important;
    margin: 1.05rem auto 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .distribution-svg-wrap {
    box-sizing: border-box !important;
    width: min(100%, 318px) !important;
    max-width: calc(100vw - 4.5rem) !important;
    margin: 1.05rem auto 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .distribution-svg-wrap {
    box-sizing: border-box !important;
    width: min(100%, 318px) !important;
    max-width: calc(100vw - 4.5rem) !important;
    margin: 1.05rem auto 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .distribution-svg-wrap {
    box-sizing: border-box !important;
    width: min(100%, 318px) !important;
    max-width: calc(100vw - 4.5rem) !important;
    margin: 1.05rem auto 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .curve-svg {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    aspect-ratio: 120 / 56 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .axis,
  .fs.fs-result-page .result-distribution .average-label,
  .fs.fs-result-page .result-distribution .score-label {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .fs.fs-result-page .result-distribution .distribution-svg-wrap {
    box-sizing: border-box !important;
    width: min(100%, 318px) !important;
    max-width: calc(100vw - 4.5rem) !important;
    margin: 1.05rem auto 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }
}

.fs .fs-modern-section,
.fs-test .fs-modern-section {
  background: var(--fs-aurora-soft);
}

.fs-test .score-mini-suffix {
  font-size: .38em;
  font-weight: 700;
  color: #6b7280;
  margin-left: .08rem;
  vertical-align: super;
}

.fs.fs-result-page {
  --result-grad: #fff;
  --result-score-grad: linear-gradient(90deg, #7dd3fc 0%, #a78bfa 48%, #f0a7d8 100%);
  --result-grad-soft: linear-gradient(90deg, rgba(147,197,253,.26), rgba(196,181,253,.30), rgba(240,167,216,.28));
}

.fs.fs-result-page .fs-section-card.result-card {
  background: #fff !important;
  border: 1px solid #dfe6f0 !important;
  border-radius: 1rem;
  box-shadow: 0 16px 40px rgba(15, 23, 42, .10) !important;
  overflow: hidden;
}

.fs.fs-result-page .result-photo-frame {
  padding: 0;
  background: #fff;
  border: 1px solid #dde3ec;
  box-shadow: 0 10px 24px rgba(15, 23, 42, .08);
}

.fs.fs-result-page .result-photo-frame img {
  border: 0;
  border-radius: .82rem;
}

.fs.fs-result-page .score-number {
  font-size: clamp(3.65rem, 12vw, 5.8rem);
}

.fs.fs-result-page .score-kicker {
  margin-bottom: .46rem;
  color: #667085;
  font-size: clamp(.84rem, 2.1vw, 1.02rem);
  font-weight: 650;
}

.fs.fs-result-page .score-outof,
.fs .score-denominator {
  font-size: clamp(.56rem, 1.45vw, .78rem);
  line-height: 1;
  font-weight: 650;
  color: #778195;
  opacity: .78;
  margin-left: .18rem;
  transform: translateY(-.22em);
}

.fs.fs-result-page .score-percentile-line {
  width: auto !important;
  max-width: none !important;
  margin-top: .3rem !important;
  padding-top: 0 !important;
  border-top: 0 !important;
  gap: .28rem;
  color: #667085;
  font-size: clamp(.88rem, 2.4vw, 1.02rem);
  font-weight: 550;
}

.fs.fs-result-page .score-percentile-line strong {
  font-size: 1.05em;
  font-weight: 780;
}

.fs.fs-result-page .part-score span {
  font-size: .54rem;
  opacity: .68;
}

.fs.fs-result-page .part-value-inline {
  display: none;
}

.fs.fs-result-page .part-row {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.fs.fs-result-page .result-distribution .score-label {
  font-size: .66rem;
  padding: .18rem .38rem;
}

.fs.fs-result-page .result-distribution {
  overflow: visible;
}

.fs.fs-result-page .result-distribution .curve-wrap {
  width: min(100%, 360px);
  max-width: 100%;
  margin: clamp(1.2rem, 4vw, 1.8rem) auto 0;
  padding: 0;
  overflow: visible;
}

.fs.fs-result-page .result-distribution .curve-svg {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 120 / 56;
  overflow: visible;
}

.fs.fs-result-page .result-distribution .curve-fill {
  fill: url(#curveGradResultPanel);
  opacity: .58;
}

.fs.fs-result-page .result-distribution .curve-stroke {
  fill: none;
  stroke: url(#curveGradResultPanel);
  stroke-width: 1.05;
}

.fs.fs-result-page .result-distribution .curve-axis-line {
  stroke: #e5e7eb;
  stroke-width: .75;
}

.fs.fs-result-page .result-distribution .average-line {
  stroke: #98a2b3;
  stroke-width: .7;
  stroke-dasharray: 1.6 1.6;
}

.fs.fs-result-page .result-distribution .score-line-svg {
  stroke: #8b7cf6;
  stroke-width: .95;
}

.fs.fs-result-page .result-distribution .axis-zero,
.fs.fs-result-page .result-distribution .axis-hundred {
  fill: #98a2b3;
  font-size: 3.6px;
  font-weight: 800;
}

.fs.fs-result-page .result-distribution .axis-zero {
  text-anchor: start;
}

.fs.fs-result-page .result-distribution .axis-hundred {
  text-anchor: end;
}

.fs.fs-result-page .result-distribution .average-svg-label {
  fill: #7a8699;
  font-size: 3.55px;
  font-weight: 850;
  text-anchor: end;
}

.fs.fs-result-page .result-distribution .distribution-svg-wrap {
  box-sizing: border-box;
  width: min(100%, 360px);
  max-width: 100%;
  margin: clamp(1.2rem, 4vw, 1.8rem) auto 0;
  padding: 0;
  overflow: visible;
}

.fs.fs-result-page .result-distribution .distribution-svg-wrap .curve-svg {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  aspect-ratio: 120 / 56;
  overflow: visible;
}

.fs.fs-result-page .result-distribution .score-svg-label rect {
  fill: #fff;
  stroke: #c4b5fd;
  stroke-width: .7;
  filter: drop-shadow(0 2px 3px rgba(124, 95, 209, .14));
}

.fs.fs-result-page .result-distribution .score-svg-label text {
  fill: #7c7eea;
  font-size: 3.35px;
  font-weight: 900;
  text-anchor: middle;
}

.fs.fs-result-page .result-distribution,
.fs.fs-result-page .result-distribution .curve-wrap,
.fs.fs-result-page .result-distribution .axis {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
}

.fs.fs-result-page .result-distribution .curve-wrap {
  padding-inline: 0 !important;
  overflow: visible;
}

.fs.fs-result-page .result-distribution .curve-svg {
  width: 100%;
  max-width: 100%;
}

.fs.fs-result-page .rank-bar,
.fs .rank-bar {
  height: 12px;
  width: calc(100% - 18px);
  margin: .72rem 9px 0;
  position: relative;
  overflow: visible !important;
  background: #eef2f7;
  border: 1px solid rgba(148,163,184,.20);
  box-shadow: inset 0 1px 2px rgba(15,23,42,.04);
}

.fs.fs-result-page .rank-bar .fill,
.fs .rank-bar .fill {
  position: relative;
  width: clamp(0%, var(--pct, 0%), 100%) !important;
  background: var(--result-grad-soft, var(--grad-primary));
  opacity: .95;
}

.fs.fs-result-page .rank-bar .fill::after,
.fs .rank-bar .fill::after {
  content: none !important;
  display: none !important;
}

.fs.fs-result-page .rank-bar::after,
.fs .rank-bar::after,
.fs.fs-result-page .rank-marker,
.fs .rank-marker {
  content: "";
  position: absolute;
  top: 50%;
  left: clamp(4%, var(--pct, 0%), 96%);
  width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #8b7cf6;
  border: 3px solid #fff;
  box-shadow: 0 8px 18px rgba(124,95,209,.28);
  transform: translate(-50%, -50%);
  box-sizing: border-box;
  z-index: 6;
}

.fs.fs-result-page .rank-marker,
.fs .rank-marker {
  display: none !important;
}

.fs.fs-result-page .rank-bar .rank-marker,
.fs .rank-bar .rank-marker {
  position: absolute !important;
  top: 50% !important;
  left: var(--marker-pct, var(--pct, 0%)) !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  background: #8b7cf6 !important;
  border: 3px solid #fff !important;
  box-shadow: 0 8px 18px rgba(124,95,209,.28) !important;
  transform: translate(-50%, -50%) !important;
  z-index: 5 !important;
  box-sizing: border-box !important;
}

.fs.fs-result-ui-test .hero-result {
  display: grid;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr);
  align-items: center;
  justify-items: center;
  gap: clamp(1rem, 4vw, 1.75rem);
  width: 100%;
  overflow: visible;
}

.fs.fs-result-ui-test .score-block {
  width: auto;
  min-width: 0;
  max-width: 100%;
  margin: 0;
  padding: .35rem 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.fs.fs-result-ui-test .score-block .score-label {
  color: #4b5563;
  font-size: .86rem;
}

.fs.fs-result-ui-test .score-block .score-value {
  min-width: 0;
  font-size: clamp(3.1rem, 13vw, 4.4rem);
  letter-spacing: 0;
}

.fs.fs-result-ui-test .score-block .score-denominator {
  font-size: .22em;
  vertical-align: super;
}

.fs-test .facescore-simple-text-widget,
.fs-test .facescore-shinndanmain,
.fs-test .fs-modern-card,
.fs-test .fs-section-card {
  box-sizing: border-box;
}

.fs-test .facescore-simple-text-widget {
  width: min(100%, 420px);
}

.fs-test .fs-modern-container {
  display: flex;
  justify-content: center;
}

.fs-test .fs-modern-card {
  width: min(100%, 420px);
  margin: 0 auto;
}

.fs-test .fs-action {
  display: flex;
  justify-content: center;
}

.fs-test .fs-primary {
  display: block;
  margin-inline: auto;
}

.fs-test .facescore-container1.fs-section {
  width: 100%;
  padding-inline: 1rem;
  box-sizing: border-box;
}

.fs-test .facescore-container1.fs-section > .fs-section-card {
  width: min(100%, 420px);
  margin-inline: auto;
  padding-inline: clamp(1rem, 5vw, 1.5rem);
}

.fs-test .facescore-shinndanexample {
  width: 100%;
  max-width: 360px;
  margin-inline: auto;
}

.fs-test .facescore-shinndanexamplediscription {
  width: 100%;
  max-width: 330px;
  text-align: center;
}

.fs-test .facescore-user {
  display: flex;
  justify-content: center;
}

.fs-test .facescore-frame5 {
  width: min(100%, 300px);
  margin-inline: auto;
  box-sizing: border-box;
}

.fs-test .facescore-container1.fs-section .facescore-img-gra {
  width: 142px;
  height: 142px;
  padding: 5px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--fs-aurora);
  box-shadow: 0 12px 28px rgba(124, 95, 209, .18);
}

.fs-test .facescore-container1.fs-section .facescore-ellipse {
  width: 132px;
  height: 132px;
  display: block;
  border: 3px solid #fff;
  box-sizing: border-box;
}

@media (max-width: 640px) {
  .fs.fs-result-page .fs-unified-container {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: .75rem !important;
    padding-right: .75rem !important;
    overflow-x: hidden;
  }

  .fs.fs-result-page .fs-section-card.result-card {
    width: 100% !important;
    max-width: 100% !important;
    padding: 1.25rem 0 1.4rem !important;
    border-radius: 1rem;
  }

  .fs.fs-result-page .result-card > :not(.fs-ad-fullbleed) {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  .fs.fs-result-page .result-score-hero {
    grid-template-columns: minmax(0, 1fr);
    justify-items: center;
    row-gap: 1rem;
    column-gap: 0;
    padding-inline: 0;
  }

  .fs.fs-result-page .result-photo-frame {
    width: min(100%, 148px);
  }

  .fs.fs-result-page .result-score-main {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .fs.fs-result-page .score-number {
    font-size: clamp(3rem, 13vw, 3.45rem);
  }

  .fs.fs-result-page .score-line {
    width: 100%;
    max-width: 100%;
    justify-content: center;
  }

  .fs.fs-result-page .score-kicker {
    margin-bottom: .34rem;
    font-size: .8rem;
  }

  .fs.fs-result-page .score-percentile-line {
    width: auto !important;
    max-width: none !important;
    margin-top: .18rem !important;
    padding-top: 0 !important;
    border-top: 0 !important;
    justify-content: center;
    font-size: .82rem;
  }

  .fs.fs-result-page .result-header .header-underline {
    width: min(8.4rem, 34vw);
    margin-top: .5rem;
  }

  .fs.fs-result-page .parts-list {
    grid-template-columns: minmax(0, 1fr);
  }

  .fs.fs-result-page .part-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: .42rem .65rem;
    min-height: 4.35rem;
  }

  .fs.fs-result-page .part-copy {
    flex: 1 1 auto;
    min-width: 0;
    width: auto;
    justify-content: flex-start;
  }

  .fs.fs-result-page .part-score {
    display: none;
    flex: 0 0 auto;
    align-items: baseline;
    justify-content: flex-end;
    min-width: 3.35rem;
    margin-left: auto;
    text-align: right;
  }

  .fs.fs-result-page .part-value-inline {
    display: inline-flex;
    flex: 0 0 auto;
    align-items: baseline;
    justify-content: flex-start;
    min-width: 0;
    margin-left: .48rem;
    color: var(--part-score-color);
    font-weight: 820;
    white-space: nowrap;
  }

  .fs.fs-result-page .part-value-inline bdi {
    font-size: .94rem;
  }

  .fs.fs-result-page .part-value-inline span {
    margin-left: .12rem;
    color: var(--result-muted);
    font-size: .52rem;
    font-weight: 650;
    opacity: .72;
  }

  .fs.fs-result-page .part-bar {
    flex: 0 0 100%;
    width: 100%;
  }

  .fs.fs-result-page .result-distribution .curve-desc {
    display: none;
  }

  .fs.fs-result-page .result-distribution,
  .fs.fs-result-page .result-distribution .curve-wrap,
  .fs.fs-result-page .result-distribution .axis {
    box-sizing: border-box !important;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .fs.fs-result-page .result-distribution {
    overflow: hidden;
  }

  .fs.fs-result-page .result-distribution .curve-wrap,
  .fs.fs-result-page .result-distribution .axis {
    width: min(320px, calc(100vw - 4.5rem)) !important;
    max-width: min(320px, calc(100vw - 4.5rem)) !important;
    margin-left: clamp(1.5rem, 8vw, 2.25rem) !important;
    margin-right: 0 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .curve-svg {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .fs.fs-result-page .result-distribution .axis .ticks {
    display: flex !important;
    justify-content: space-between;
    align-items: flex-start;
    height: 1rem;
    font-size: .64rem;
  }

  .fs.fs-result-page .result-distribution .axis {
    height: 1.05rem;
  }

  .fs.fs-result-page .result-distribution .axis::before,
  .fs.fs-result-page .result-distribution .axis::after {
    content: none !important;
  }

  .fs.fs-result-page .result-distribution .axis .ticks span {
    display: none;
  }

  .fs.fs-result-page .result-distribution .axis .ticks span:first-child,
  .fs.fs-result-page .result-distribution .axis .ticks span:last-child {
    display: inline;
    color: #98a2b3;
    font-weight: 700;
  }

  .fs.fs-result-page .result-distribution .axis .ticks span:first-child {
    min-width: 1.2rem;
    text-align: left;
  }

  .fs.fs-result-page .result-distribution .axis .ticks span:last-child {
    min-width: 2rem;
    text-align: right;
    transform: translateX(-1.15rem);
  }

  .fs.fs-result-page .result-distribution .average-label,
  .fs.fs-result-page .result-distribution .score-label {
    max-width: 4.8rem;
  }

  .fs.fs-result-page .score-outof,
  .fs .score-denominator {
    font-size: .62rem;
    transform: translateY(-.18em);
  }

  .fs.fs-result-ui-test .hero-result {
    grid-template-columns: minmax(0, 1fr);
    row-gap: .9rem;
  }

  .fs-test .facescore-simple-text-widget {
    width: 100%;
    max-width: 390px;
  }

  .fs-test .facescore-container1.fs-section {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    padding-inline: .75rem;
    align-items: stretch;
  }

  .fs-test .facescore-container1.fs-section > .fs-section-card {
    width: 100%;
    max-width: 350px;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    transform: translateX(clamp(-58px, -14vw, -44px));
  }

  .fs-test .facescore-frame5 {
    width: min(100%, 280px);
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}

@media (max-width: 640px) {
  .fs.fs-result-page,
  .fs.fs-result-page * {
    box-sizing: border-box;
  }

  .fs.fs-result-page {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip !important;
  }

  .fs.fs-result-page .fs-section {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip !important;
  }

  .fs.fs-result-page .fs-unified-container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: .75rem !important;
    padding-right: .75rem !important;
    overflow-x: visible !important;
  }

  .fs.fs-result-page .fs-section-card.result-card {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 1.25rem 0 1.4rem !important;
    overflow: hidden !important;
    transform: none !important;
  }

  .fs.fs-result-page .result-card > :not(.result-card-bg):not(.fs-ad-fullbleed) {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    overflow-x: visible !important;
  }

  .fs.fs-result-page .result-score-panel,
  .fs.fs-result-page .result-score-hero,
  .fs.fs-result-page .result-score-main,
  .fs.fs-result-page .score-line,
  .fs.fs-result-page .result-parts,
  .fs.fs-result-page .parts-list,
  .fs.fs-result-page .part-row,
  .fs.fs-result-page .part-copy,
  .fs.fs-result-page .part-bar,
  .fs.fs-result-page .result-ranking,
  .fs.fs-result-page .rank-card,
  .fs.fs-result-page .rank-bar,
  .fs.fs-result-page .result-distribution {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .fs.fs-result-page .part-row {
    overflow: hidden !important;
  }

  .fs.fs-result-page .part-copy {
    flex: 1 1 0 !important;
  }

  .fs.fs-result-page .part-value-inline {
    flex-shrink: 0 !important;
  }

  .fs.fs-result-page .part-bar {
    flex: 0 0 100% !important;
  }

  .fs.fs-result-page .result-distribution {
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .curve-wrap,
  .fs.fs-result-page .result-distribution .distribution-svg-wrap {
    width: min(100%, 292px) !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 1.05rem auto 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .curve-svg {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    aspect-ratio: 120 / 56 !important;
    overflow: visible !important;
  }

  .fs.fs-result-page .result-distribution .axis,
  .fs.fs-result-page .result-distribution .average-label,
  .fs.fs-result-page .result-distribution .score-label {
    display: none !important;
  }
}
