:root {
  --myq-black: #1d1d1d;
  --myq-black-light: #555;
  --myq-brown: #743600; 
  --myq-brown-light: rgb(116, 54, 0,0.05); 
  --myq-line: #b8b8b8;
  --gold: #b7965d;
  --text: #1d1d1d;
  --myq-gray: #777;
  --pale: #f7f9f8;
  --myq-line: #b8b8b8;
  --myq-line-dark: #8d8d8d;
  --page-min: 430px;
  --page-max: 560px;
  --section-pad: clamp(14px, calc(8.125vw - 20.94px), 40px);
  --myq-font: "Noto Sans JP", "Noto Sans Medium", "Yu Gothic", "YuGothic", "游ゴシック体", "Yu Gothic Medium", "Hiragino Sans", "ヒラギノ角ゴ ProN W3", sans-serif;
  --qa-sticky-top-sp: 50px;
  --qa-sticky-top-pc: 50px;
  --qa-progress-height: 44px;
}

* {
box-sizing: border-box;
}

html {
scroll-behavior: smooth;
  width: 100%;
  max-width: 100%;
  overflow-x: clip;
}

.container-fluid {
margin-right: auto;
    margin-left: auto;
    padding-left: 0;
    padding-right: 0;
}

body {
margin: 0;
  min-width: 0;
  width: 100%;
  max-width: 100%;
  color: var(--text);
  background: #eeeeee;
  letter-spacing: 0;
  overflow-x: clip;
}

#wrapper,
#contents,
#main,
#main_middle,
.cd-main-content,
.page-shell {
max-width: 100%;
}

#header {
z-index: 1000 !important;
}

.page-shell {
position: relative;
  width: 100%;
  max-width: 560px;
  min-height: 100vh;
  margin: 0 auto;
  overflow: visible;
  background: #ffffff;
}

.section-white,
.section-gray {
padding-inline: 22px;
}
@media screen and (min-width: 560px) {
.section-white,
.section-gray  {
    padding-inline: 44px;
  }
}


.section-white {
background: #ffffff;
}

.section-gray {
background: var(--pale);
}

.eyebrow {
margin: 0;
  color: var(--myq-brown);
  font-size: 14px;
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: 0.16em;
  text-align: center;
}


.page-shell,
.consultation {
overflow: visible;
}

button,
input,
select,
a {
font: inherit;
}

button {
border: 0;
  cursor: pointer;
}

button:focus,
select:focus,
input:focus,
a:focus {
outline: none;
}

[hidden] {
display: none !important;
}

a:hover,
a:focus,
a:active {
text-decoration: none;
	outline: none;
}

.page-shell {
  position: relative;
  width: 100%;
  max-width: 560px;
  min-height: 100vh;
  margin: 0 auto;
  overflow: visible;
  background: #ffffff;
}

/* PCアクセス時: LP は表示し、診断フォームのみ開始できないようにする */

main.page-shell.ain-pc-blocked #aiSkinNavi {
display: none !important;
}

main.page-shell.ain-pc-blocked #ain-intro-panel {
display: none !important;
}

.pc-blocked {
min-height: 100vh;
  padding: 90px 22px 70px;
  text-align: center;
}
@media screen and (min-width: 560px) {
	.pc-blocked {
      padding: 90px 44px 70px;
  }
}

.pc-blocked h2 {
margin: 18px auto 0;
  color: #222222;
  font-size: 24px;
  line-height: 1.6;
}

.pc-blocked p:not(.eyebrow) {
margin: 24px auto 0;
  color: #555555;
  font-size: 15px;
  line-height: 1.9;
}

/* 撮影手順へ進む押下後: LP / intro / 設問を隠し撮影 UI のみ */

main.page-shell.ain-capture-focus > *:not(#aiSkinNavi):not(#skin_image_terms_ainavi) {
display: none !important;
}

main.page-shell.ain-capture-focus #consultation {
display: none !important;
}

#photoSection.ain-capture-only-wizard > *:not(#ainCameraCaptureRoot):not(.eyebrow) {
display: none !important;
}


.photo-analysis > p:not(.eyebrow),
.complete > p:not(.eyebrow) {
width: min(100%, 560px);
  margin-inline: auto;
  text-align: center;
}

.doctor-note {
margin: 5px 0;
    color: #555;
    font-size: 9px;
    line-height: 15px;
}


.intro-start {
  border-top: 50px solid var(--myq-black);
  padding: 100px 22px 80px;
  text-align: center;
}


@media (min-width: 560px) {
  .intro-start {
  padding: 120px 44px 80px;
  }
}

.intro-start h1 {
  color: var(--myq-black);	
  font-family: var(--myq-font);
  margin: 0 auto 30px;
  font-size: 22px;
  line-height: 1.75;
  animation: introButtonFadeIn 0.72s ease-out both;
  font-weight: 500;
  text-align: left;
  line-height: 40px;
  text-indent: -13px;
}
.intro-start h1 span {
  color: var(--myq-brown);	
}

.intro-start-lead {
    margin: 0 0 10px;
    color: var(--myq-black);
    font-size: 15px;
    line-height: 2.05;
    text-align: left;
}

.intro-start-note {
margin: 50px auto -20px;
  color: #555;
  font-size: 14px;
  line-height: 24px;
  text-align: center;
}

.intro-start-user {
margin: 20px auto 0;
  color: #333;
  font-size: 16px;
  line-height: 24px;
}

p.threemin {
font-size: 12px;
    padding: 3px 16px 2px;
    border: 1px solid #777;
    display: inline-block;
    margin-top: 30px;
    border-radius: 5px;
}

.intro-start-divider {
width: 160px;
  margin: 28px auto;
  border: 0;
  border-top: 1px solid #e5e5e5;
}

.intro-start-btn {
gap: 6px;
  animation: introButtonFadeIn 0.72s ease-out both;
}

.intro-start-btn .fa {
font-size: 12px;
}

@keyframes introButtonFadeIn {
from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.consultation {
position: relative;
  padding-top: 30px;
  padding-bottom: 30px;
}

.progress-panel-marker {
display: none;
}

.progress-panel {
position: sticky;
  top: var(--qa-sticky-top-pc);
  z-index: 80;
  width: calc(100% + (var(--section-pad) * 2));
  margin: 0 calc(var(--section-pad) * -1) clamp(22px, 5.12vw, 38px);
  padding: 10px var(--section-pad) 10px;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-sizing: border-box;
  border-bottom: 1px solid #eee;
}

@media screen and (max-width: 767px) {
.progress-panel-marker {
display: block;
    height: 0;
}

.progress-panel {
position: relative;
    top: auto;
    left: auto;
    z-index: 80;
    width: calc(100% + (var(--section-pad) * 2));
    margin: 0 calc(var(--section-pad) * -1) clamp(22px, 5.12vw, 38px);
    padding: 8px var(--section-pad) 9px;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

body.is-consultation-progress-fixed .progress-panel-marker {
height: var(--qa-progress-height);
    margin-bottom: clamp(22px, 5.12vw, 38px);
}

body.is-consultation-progress-fixed .progress-panel {
position: fixed;
    top: var(--qa-sticky-top-sp);
    left: 50%;
    z-index: 900;
    width: min(100vw, 560px);
    margin: 0;
    transform: translateX(-50%);
}
}

.progress-panel > div {
display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 5px;
}

.progress-panel span,
.progress-panel b {
color: var(--myq-brown);
  font-size: 11px;
  font-weight: 500;
}

@media screen and (min-width: 560px) {
.progress-panel span,
.progress-panel b {
font-size: 13px;
}
}

.progress-panel i {
display: block;
  height: clamp(4px, 0.93vw, 7px);
  overflow: hidden;
  border-radius: 999px;
  background: #e4ece9;
}

.progress-panel i span {
display: block;
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: var(--myq-brown);
  transition: width 0.5s ease;
}

.question-card,
.photo-analysis,
.analyzing,
.complete {
scroll-margin-top: calc(var(--qa-sticky-top-sp) + var(--qa-progress-height) + 24px);
}

@media screen and (min-width: 760px) {
.question-card,
.photo-analysis,
.analyzing,
.complete {
scroll-margin-top: calc(var(--qa-sticky-top-pc) + var(--qa-progress-height) + 24px);
}
}

.question-card {
display: none;
  width: min(100%, 560px);
  margin: 0 auto 50px;
  padding: 40px 0 50px;
  border-bottom: 1px solid #dfdfdf;
  background: #ffffff;
  opacity: 0;
  transform: translateY(18px);
  text-align: center;
}

.question-card div {
padding: 0 0 20px;
    text-align: left;
    color: #555;
}

.question-card + .question-card {
border-top: 0;
}

.question-card.is-active,
.question-card.is-complete {
display: block;
  animation: cardIn 0.48s ease forwards;
}

@keyframes cardIn {
to {
    opacity: 1;
    transform: translateY(0);
  }
}

.intro-start p.eyebrow {
	margin-bottom: 40px;
    color: var(--myq-black);
    font-size: 12px;
    font-weight: 600;
    line-height: 1.4;
    letter-spacing: 0.08em;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    text-align: left;
}

.question-card .eyebrow {
	margin-bottom: 40px;
    color: var(--myq-brown);
    font-size: 12px;
    letter-spacing: 0.08em;
    text-align: left;    
}

.question-card h2 {
	font-size: 20px;
    line-height: 1.75;
    margin-bottom: 30px;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    text-align: left;
    font-weight: 400;
    color: var(--myq-black);
}

.question-card > p:not(.eyebrow):not(.bridge) {
	margin: 0px auto 15px;
    font-size: 13px;
    line-height: 22px;
    text-align: left;    
    color: var(--myq-black-light);
}

.select-row {
display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(10px, 2.33vw, 18px);
  width: min(100%, 390px);
  margin: clamp(21px, 4.88vw, 37px) auto clamp(20px, 4.65vw, 35px);
}

.select-row select {
width: 100%;
    height: 45px;
    padding: 2px 15px;
    border: 1px solid #d7d7d7;
    border-radius: 3px;
    background: #ffffff;
    color: #333;
    font-size: 14px;
}

.question-card > button:not(.next-btn):not(.question-back-btn) {
position: relative;
    display: block;
    width: 100%;
    min-height: 50px;
    margin-top: 15px;
    padding: 15px 30px;
    border: 1px solid #dddddd;
    border-radius: 6px;
    background: #ffffff;
    color: #333;
    font-size: 14px;
    line-height: 22px;
    transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
    text-align: left;
}

.question-card[data-type="multi"] > button:not(.next-btn):not(.question-back-btn) {
padding-left: 60px;
}

.question-card[data-type="single"] > button:not(.next-btn):not(.question-back-btn) {
padding-left: 35px;
text-align: left;
}

.question-card[data-type="multi"] > button:not(.next-btn):not(.question-back-btn)::before {
content: "";
  position: absolute;
  left: 14px;
  top: 50%;
  width: 24px;
  height: 24px;
  border: 1px solid var(--myq-brown);
  border-radius: 50%;
  transform: translateY(-50%);
}

.question-card[data-type="multi"] > button:not(.next-btn):not(.question-back-btn)::after {
content: "";
    position: absolute;
    left: 22px;
    top: 50%;
    width: 8px;
    height: 12px;
    border-right: 1.5px solid #ffffff;
    border-bottom: 1.5px solid #ffffff;
    opacity: 0;
    transform: translateY(-58%) rotate(45deg);
}

.question-card > button.is-selected:not(.next-btn):not(.question-back-btn) {
border-color: var(--myq-brown);
  background: var(--myq-brown-light);
  color: var(--myq-brown);
}

.question-card[data-type="multi"] > button.is-selected:not(.next-btn):not(.question-back-btn)::before {
border-color: var(--myq-brown);
  background: var(--myq-brown);
}

.question-card[data-type="multi"] > button.is-selected:not(.next-btn):not(.question-back-btn)::after {
opacity: 1;
}

.question-card[data-legacy-question="q5"] > button:not(.next-btn):not(.question-back-btn) {
padding-right: 70px;
}

.question-back-btn {
　display: block;
  width: auto;
  margin: 30px auto 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: #777;
  font-size: 13px;
  line-height: 1.5;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
  text-decoration-color: #bbb;
  text-align: center;
}

.question-back-btn:hover {
color: #555555;
}

.q5-rank-badge {
position: absolute;
  right: 14px;
  top: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--myq-brown);
  color: #ffffff;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  transform: translateY(-50%);
  pointer-events: none;
}

.next-btn,
.camera-btn,
.report-btn {
display: flex;
  align-items: center;
  justify-content: center;
  width: min(100%, 250px);
  min-height: 45px;
  margin: 30px auto 0;
  background: var(--myq-brown);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
  text-decoration: none;
  transition: opacity 0.2s ease, background-color 0.2s ease;
}

.next-btn:disabled,
.report-btn.is-disabled {
background: #d8d8d8;
  color: #ffffff;
  cursor: default;
}

.bridge {
display: none;
  width: min(100%, 560px);
  margin: 60px auto 20px;
  color: var(--myq-brown);
  font-size: 15px;
  line-height: 2;
  text-align: center;
}

.question-card.is-complete .bridge {
display: block;
  animation: bridgeRevealCycle 3.00s both;
}

@keyframes bridgeRevealCycle {
0% {
    opacity: 0;
    transform: translateY(-10px);
    animation-timing-function: ease-out;
  }

  25% {
    opacity: 1;
    transform: translateY(0);
    animation-timing-function: linear;
  }

  80% {
    opacity: 1;
    transform: translateY(0);
    animation-timing-function: ease-in;
  }

  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}

.photo-analysis,
.analyzing,
.complete {
padding-top: 70px;
  padding-bottom: 70px;
  border-top: 1px solid #dfdfdf;
  text-align: center;
}

.complete > p:not(.eyebrow) {
text-align: left;
  line-height: 25px;
  margin: 21px auto;
  width: 90%;
}

.photo-analysis h2,
.analyzing h2,
.complete h2 {
	font-size: 20px;
    line-height: 1.75;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-weight: 400;
	margin-top: 30px;
	text-align: center;
	color: var(--myq-black);
}

p.photo_txt {
line-height: 24px;
    margin-top: 20px;
    color: #555;
}

.photo-frame {
border: 1px dotted #ccc;
    margin: 20px auto 10px;
    padding: 10px;
    border-radius: 5px;
}

.photo-guide {
width: 140px;
  margin: 20px auto 15px;
}

.privacy {
display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: min(100%, 560px);
    margin: 0 auto 20px;
}

.consent {
display: inline-flex;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
}

.privacy-key {
width: 18px;
  height: auto;
}

.privacy span {
color: #555;
    font-size: 13px;
    line-height: 20px;
    padding-top: 5px;
}

.consent input {
width: 26px;
    height: 26px;
    accent-color: var(--myq-brown);
    margin-right: 6px;
}

.consent span {
font-size: 16px;
    color: #333;
    padding: 1px 0;
}

.camera-btn {
gap: 10px;
}

.camera-btn img {
padding-top: 1px;
}

.camera-btn span {
padding-top: 0;
}

.camera-btn:disabled {
background: #d8d8d8;
  cursor: default;
}

.form-note {
margin: 14px auto 0;
    color: #555;
    font-size: 13px;
    line-height: 1.6;
	text-align: center;
}

.form-note2 {
color: #966f4a;
    font-size: 13px;
    line-height: 1.6;
	text-align: center;
}

.form-note3 {
color: #966f4a;
    font-size: 13px;
    line-height: 1.6;
	text-align: center;
	margin-top: 14px;
}

.loader {
position: relative;
  width: clamp(106px, 24.65vw, 185px);
  height: clamp(106px, 24.65vw, 185px);
  margin: clamp(34px, 7.91vw, 59px) auto clamp(24px, 5.58vw, 42px);
  border-radius: 50%;
}

.loader::before,
.loader::after {
content: "";
  position: absolute;
  inset: clamp(10px, 2.33vw, 18px);
  border-radius: 50%;
}

.loader::before {
border: 1px solid var(--myq-brown);
  border-left-color: transparent;
  animation: spin 1.8s linear infinite;
}

.loader::after {
display: none;
}

.loader span {
position: absolute;
  left: 50%;
  top: 50%;
  color: var(--myq-brown);
  font-size: clamp(12px, 2.79vw, 21px);
  letter-spacing: 0;
  transform: translate(-50%, -50%);
}

.analyzing.is-complete .loader::before {
border-color: var(--myq-brown);
  animation: none;
}

.analyzing.is-complete .loader::after {
display: block;
  inset: auto auto clamp(28px, 6.51vw, 49px) 50%;
  border-right: 0;
  border-top: 0;
  transform: translateX(-50%) rotate(-45deg);
}

@keyframes spin {
to {
    transform: rotate(360deg);
  }
}

#analysisSteps {
display: grid;
  gap: 12px;
  width: min(100%, 430px);
  margin: 40px auto 0;
  padding: 0;
  list-style: none;
}

#analysisSteps li {
padding: 0;
  border: 0;
  color: #333333;
  font-size: 15px;
  line-height: 1.55;
  text-align: center;
  transition: color 0.25s ease;
}

#analysisSteps li.is-current,
#analysisSteps li.is-done {
color: var(--myq-brown);
}

#analysisSteps li.is-done {
font-weight: 600;
}

.doctor-sign {
display: flex;
    gap: 25px;
    align-items: center;
    justify-content: center;
    width: 90%;
    margin: 40px auto 10px;
    text-align: left;
}

.doctor-sign img {
width: 100px;
  height: 100px;
}

.doctor-sign p,
.doctor-sign strong,
.doctor-sign span {
display: block;
}

.doctor-sign p {
color: var(--myq-brown);
  margin-bottom: 2px;
  font-size: 12px;
  line-height: 1.4;
}

.doctor-sign p.detail {
color: #777;
  margin-bottom: 5px;
  font-size: 11px;
  line-height: 1.4;
}

.doctor-sign strong {
color: #333842;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.35;
}

span.red_line {
display: block;
    width: 80px;
    height: 1px;
    margin: 8px 0;
    background: var(--red-line);
}

.email-form {
width: min(90%, 560px);
  margin: 0 auto;
  padding-top: 26px;
  border-top: 1px solid #ccc;
}

.email-form p {
margin-bottom: 16px;
  color: #333333;
  font-size: 14px;
  line-height: 1.75;
  text-align: center;
}

.email-form p span {
color: #d33845;
}

.email-form input {
width: 90%;
  height: 45px;
  padding: 0 16px;
  border: 1px solid var(--myq-brown);
  border-radius: 3px;
  color: #333333;
  font-size: 15px;
}

.email-form small {
display: block;
  margin-top: 10px;
  color: #777;
  font-size: 13px;
  line-height: 20px;
  text-align: left;
}

.report-btn {
width: min(100%, 360px);
  margin-top: 22px;
}

@media (hover: hover) {
.question-card > button:not(.next-btn):not(.question-back-btn):hover {
border-color: var(--myq-brown);
}

.next-btn:not(:disabled):hover,
.camera-btn:not(:disabled):hover,
.report-btn:not(.is-disabled):hover {
opacity: 0.86;
}
}

@media (prefers-reduced-motion: reduce) {
html {
scroll-behavior: auto;
}

*,
*::before,
*::after {
animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
}

.question-card.is-complete .bridge {
animation: none !important;
    opacity: 1;
    transform: none;
}

:root {
--site-header-height: 72px;
}
}

/* AI Skin Navi camera capture UI */

:root {
--capture-green: #75ab9d;
  --capture-green-dark: #006666;
  --capture-cyan: #2df8f0;
  --capture-bg: #eaf5ff;
  --capture-shadow: 0 5px 8px rgba(42, 72, 96, 0.15);
}

.admin-camera-skip,
.capture-admin-skip {
width: min(88%, 430px);
  margin: 18px auto 0;
  text-align: center;
}

.admin-camera-skip button,
.capture-admin-skip button {
min-height: 42px;
  padding: 0 20px;
  border: 1px solid var(--myq-brown);
  border-radius: 999px;
  background: #ffffff;
  color: var(--myq-brown);
  font-size: 13px;
  font-weight: 600;
}

.admin-camera-skip .notes-subtitle,
.capture-admin-skip .notes-subtitle {
margin-top: 8px;
  color: #777777;
  font-size: 11px;
  line-height: 1.5;
}

#ainCameraCaptureRoot {
width: min(100%, 750px);
  margin: 28px auto 0;
}

.Image__capture {
color: #3f3f3f;
  letter-spacing: 0;
}

.Image__capture__consent,
.Image__capture__guideline,
.Image__capture__advice,
.Image__capture__loading,
.Image__capture__error {
background: none;
}

.Image__capture__consent {
width: min(88%, 430px);
  margin: 0 auto;
  padding: 36px 22px 34px;
  background: #ffffff;
  box-shadow: var(--capture-shadow);
  text-align: center;
}

.Image__capture__consent__title {
margin: 0 0 14px;
  color: #333333;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.55;
  text-align: center;
}

.Image__capture__consent .notes-subtitle {
margin: 0 auto 18px;
  color: #555555;
  font-size: 13px;
  line-height: 1.8;
  text-align: left;
}

.Image__capture__consent .error {
margin: 14px 0;
  color: #a14543;
  font-size: 13px;
  line-height: 1.7;
  text-align: left;
}

.Image__capture__consent .img img {
width: 118px;
  margin: 18px auto 20px;
}

.Image__capture__consent label {
display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  color: #333333;
  font-size: 14px;
}

.Image__capture__consent input[type="checkbox"] {
width: 22px;
  height: 22px;
  accent-color: var(--myq-brown);
}

.Image__capture__consent a {
color: var(--myq-brown);
  text-decoration: underline;
  text-underline-offset: 3px;
}

#nextBtn_camera_capture,
.next-prev--guideline .next {
display: flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 250px);
    min-height: 45px;
    margin: 30px auto 0;
    border-radius: 999px;
    background: var(--myq-brown);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none;
    transition: opacity 0.2s ease, background-color 0.2s ease;
    gap: 12px;
}

#nextBtn_camera_capture.nextBtn--invalid,
#nextBtn_camera_capture:disabled {
background: #d8d8d8;
  color: #ffffff;
  cursor: default;
}

#nextBtn_camera_capture .icon {
width: 28px;
  margin-right: 10px;
}

#nextBtn_camera_capture .icon img {
width: 100%;
}

#nextBtn_camera_capture .txt {
display: inline-flex;
  align-items: center;
  gap: 8px;
}

.Image__capture__guideline {

}

.Image__capture__guideline .Image__capture__guideline__box {
width: min(100%, 560px);
  margin: 0 auto;
  padding: 36px 24px 34px;
  background: #ffffff;
/*   box-shadow: var(--capture-shadow); */
}

.Image__capture__guideline .Image__capture__guideline__box > p:first-child {
margin: 0 0 28px;
  color: #333333;
  font-size: 23px;
  font-weight: 400;
  line-height: 1.45;
  text-align: center;
}

.Image__capture__guideline .flow {
display: grid;
  gap: 20px;
  width: min(100%, 560px);
  margin: 0 auto 34px;
  padding: 0;
  list-style: none;
}

.Image__capture__guideline .flow li {
position: relative;
  display: grid;
  grid-template-columns: 64px 1fr;
  min-height: 52px;
  border: 1px solid var(--myq-brown);
  color: var(--myq-brown);
  font-size: 18px;
  font-weight: 600;
  line-height: 52px;
  text-align: center;
}

.Image__capture__guideline .flow li + li::before {
content: "";
  position: absolute;
  left: 50%;
  top: -14px;
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 10px solid #d5d5d5;
  transform: translateX(-50%);
}

.Image__capture__guideline .flow span {
display: block;
  background: var(--myq-brown);
  color: #ffffff;
  font-weight: 600;
}

.Image__capture__guideline .notes {
display: grid;
  gap: 22px;
  width: min(100%, 510px);
  margin: 0 auto;
}

.Image__capture__guideline .notes p {
display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  margin: 0;
  color: #3d3d3d;
  font-size: 14px;
  line-height: 22px;
  text-align: left;
}

.Image__capture__guideline .notes span {
display: flex;
  align-items: center;
  justify-content: center;
}

.Image__capture__guideline .notes img {
width: 38px;
  max-height: 46px;
  object-fit: contain;
}

.next-prev--guideline {
width: min(100%, 690px);
  margin: 30px auto 0;
  text-align: center;
}

.next-prev--guideline .next i {
margin-left: 12px;
  font-size: 16px;
}

.next-prev--guideline .back {
display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 28px;
  background: transparent;
  color: #777777;
  font-size: 18px;
}

.Image__capture__advice,
.Image__capture__loading,
.Image__capture__error {
min-height: 100svh;
  padding: 42px 18px 72px;
}

.Image__capture__advice .Image__capture__guideline__box,
.Image__capture__error__box {
width: min(100%, 690px);
  margin: 0 auto;
  padding: 38px 22px;
  background: #ffffff;
  box-shadow: var(--capture-shadow);
  text-align: center;
}

.capture-advice-title {
margin: 0 0 26px;
  color: #333333;
  font-size: clamp(22px, 5vw, 31px);
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
}

.capture-advice-image img {
width: min(78%, 390px);
  margin: 0 auto;
}

.Image__capture__loading {
display: flex;
  align-items: center;
  justify-content: center;
}

.loading_desc {
transform: translateY(-8vh);
}

.loading_desc p {
margin: 0 0 22px;
  color: #333333;
  font-size: 18px;
  line-height: 1.6;
  text-align: center;
}

.loading_icon img,
.Image__capture__loading .pc_only {
display: block !important;
}

.loading_icon img {
width: 88px;
  margin: 0 auto;
  animation: captureSpin 1.1s linear infinite;
}

@keyframes captureSpin {
to { transform: rotate(360deg); }
}

.Image__capture__error {
padding-top: 52px;
}

.Image__capture__error__box {
padding: 34px 26px 36px;
}

.error_msg,
.forehead_error,
.too_dark_error,
.face_size_error,
.face_error,
.Image__capture__error__message p {
position: relative;
  margin: 0 auto 28px;
  padding-left: 40px;
  color: #333333;
  font-size: 16px;
  line-height: 1.75;
  text-align: left;
}

.Image__capture__error__message p::before {
content: "△";
  position: absolute;
  left: 0;
  top: 0.08em;
  color: #d33845;
  font-size: 28px;
  line-height: 1;
}

.Image__capture__error__box__title {
font-size: 18px;
    font-weight: 600;
    color: var(--myq-brown);
    margin-bottom: 20px;
}

.Image__capture__error__box .Image__capture__error__back {
margin-top: 18px;
}

.Image__capture__error__box button.next {
display: flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 250px);
    min-height: 45px;
    margin: 30px auto 0;
    border-radius: 999px;
    background: var(--myq-brown);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
    text-decoration: none;
    transition: opacity 0.2s ease, background-color 0.2s ease;
}

.Image__capture__main {
position: fixed;
  inset: 0;
  z-index: 5000;
  min-height: 100dvh;
  overflow: hidden;
  background: #111111;
}

.Image__capture__layer.-back,
.Image__capture__layer.-front {
position: absolute;
  inset: 0;
}

.Image__capture__layer.-back {
z-index: 1;
}

.Image__capture__frame {
display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #111111;
  transform: scaleX(-1);
}

.Image__capture__layer.-front {
z-index: 2;
  background: rgba(0, 0, 0, 0.18);
  pointer-events: none;
}

.Image__capture__layer__inner {
position: relative;
  width: 100%;
  height: 100%;
  --guide-w: min(95vw, 520px);
  --guide-h: min(60vh, 760px);
  --guide-top: 39%;
}

.Image__capture__layer__inner::before {
content: "";
  position: absolute;
  left: 50%;
  top: var(--guide-top);
  width: var(--guide-w);
  height: var(--guide-h);
  border: 3px solid rgba(255, 255, 255, 0.42);
  border-radius: 50%;
  box-shadow: 0 0 0 9999px rgba(0, 0, 0, 0.42);
  transform: translate(-50%, -50%);
}

.Image__capture__layer__inner::after {
content: "";
  position: absolute;
  left: 50%;
  top: var(--guide-top);
  width: 1px;
  height: var(--guide-h);
  border-radius: 999px;
  background: var(--capture-cyan);
  transform: translate(-50%, -50%);
}

.Image__capture__layer.-front::after {
content: "";
  position: absolute;
  left: 50%;
  top: 39%;
  width: min(85vw, 470px);
  height: 1px;
  border-radius: 999px;
  background: var(--capture-cyan);
  transform: translate(-50%, -50%);
}

.Image__capture__layer__inner.right::after,
.Image__capture__layer__inner.left::after {
width: calc(var(--guide-w) * 0.36);
  height: calc(var(--guide-h) * 1);
  background: transparent;
  border: 1px solid var(--capture-cyan);
  border-left: 0;
  border-top-color: transparent;
  border-bottom-color: transparent;
  border-radius: 50%;
}

.Image__capture__layer__inner.right::after {
left: calc(57% + var(--guide-w) * 0);
    transform: translate(-50%, -50%) scaleX(-1);
}

.Image__capture__layer__inner.left::after {
left: calc(43% - var(--guide-w) * 0);
}

.Image__capture__title {
position: absolute;
  left: 50%;
  top: max(18px, env(safe-area-inset-top));
  z-index: 3;
  width: min(88vw, 620px);
  margin: 0;
  color: #ffffff;
  font-size: 20px;
  font-weight: 400;
  line-height: 26px;
  text-align: center;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
  transform: translateX(-50%);
}

.Image__capture__title p {
display: inline-block;
  min-width: 64px;
  margin: 12px auto 0;
  padding: 5px 14px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.45);
  color: #ffffff;
  font-size: 42px;
  line-height: 1;
}

.nav_and_button {
position: absolute;
  left: 50%;
  bottom: max(24px, env(safe-area-inset-bottom));
  z-index: 3;
  display: grid;
  justify-items: center;
  gap: 18px;
  width: min(96vw, 680px);
  transform: translateX(-50%);
  pointer-events: auto;
}

.nav_and_button .progress {
display: flex;
  justify-content: center;
  gap: clamp(12px, 3vw, 30px);
  width: 100%;
}

.Image__capture__nav {
position: relative;
  display: grid;
  place-items: center;
  width: clamp(82px, 24vw, 132px);
  height: clamp(82px, 24vw, 132px);
  border: 3px solid rgba(255, 255, 255, 0.92);
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.22);
  color: #ffffff;
}

.Image__capture__nav.active,
.Image__capture__nav.done {
border-color: var(--capture-cyan);
  color: var(--capture-cyan);
}

.Image__capture__nav .status {
display: none;
  width: 100%;
  height: 100%;
}

.Image__capture__nav .status img {
width: 100%;
  height: 100%;
  object-fit: contain;
}

.Image__capture__nav .status.-nextup {
display: block;
}

.Image__capture__nav.active .status,
.Image__capture__nav.done .status {
display: none;
}

.Image__capture__nav.active .status.-current,
.Image__capture__nav.done .status.-done {
display: block;
}

.Image__capture__timer {
display: grid;
  place-items: center;
  width: clamp(104px, 29vw, 150px);
  height: clamp(104px, 29vw, 150px);
  padding: 0;
  border: 12px solid rgba(0, 0, 0, 0.42);
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22);
}

.Image__capture__timer img {
width: 100%;
  height: 100%;
  object-fit: contain;
}

.Image__capture__timer .pc_only {
display: none !important;
}

.Image__capture__timer .sp_only {
display: block !important;
}

@media screen and (min-width: 760px) {
.Image__capture__guideline,
.Image__capture__advice,
.Image__capture__loading,
.Image__capture__error {

}

.Image__capture__main {
left: 50%;
    width: min(100vw, 750px);
    transform: translateX(-50%);
}
}

@media screen and (max-width: 520px) {
.Image__capture__guideline,
.Image__capture__advice,
.Image__capture__loading,
.Image__capture__error {
padding-right: 10px;
    padding-left: 10px;
}

.Image__capture__guideline .Image__capture__guideline__box,
.Image__capture__advice .Image__capture__guideline__box,
.Image__capture__error__box {
padding-right: 10px;
    padding-left: 10px;
}

.Image__capture__guideline .notes p {
grid-template-columns: 46px 1fr;
    gap: 12px;
}

.Image__capture__guideline .notes img {
width: 34px;
}
}

/* AI Skin Navi terms modal */

.term_link {
text-underline-offset: 6px;
    text-decoration: underline;
    text-decoration-color: #999;
    color: #777;
}

#skin_image_terms_ainavi {
display: none !important;
}

#skin_image_terms_ainavi.ain-skin-terms-modal.is-open {
display: block !important;
}

.ain-skin-terms-overlay {
position: fixed;
  inset: 0;
  z-index: 100040;
  display: none;
  width: 100%;
  height: 100%;
  padding: 0;
  border: 0;
  background: rgba(0, 0, 0, 0.45);
  cursor: pointer;
}

.ain-skin-terms-overlay.is-open {
display: block;
}

.ain-skin-terms-modal {
position: fixed;
  top: 50%;
  left: 50%;
  z-index: 100050;
  display: none;
  width: min(88vw, 430px);
  max-height: min(76vh, 620px);
  padding: 28px 22px 24px;
  overflow-y: auto;
  background: #ffffff;
  border-radius: 8px;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.22);
  transform: translate(-50%, -50%);
}

.ain-skin-terms-modal.is-open {
display: block;
}

.ain-skin-terms-modal p,
.ain-skin-terms-modal li,
.ain-skin-terms-modal dt,
.ain-skin-terms-modal dd {
font-size: 13px;
  line-height: 19px;
  text-align: left;
}

.ain-skin-terms-modal h1,
.ain-skin-terms-modal h2,
.ain-skin-terms-modal h3 {
margin: 0 0 14px;
  font-size: 13px;
  line-height: 1.6;
  text-align: left;
  font-weight: 600;
}

.ain-skin-terms-close {
position: sticky;
  top: -16px;
  z-index: 1;
  display: block;
  width: 32px;
  height: 32px;
  margin: -12px -8px 6px auto;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: #ffffff;
  color: #333333;
  font-size: 24px;
  line-height: 32px;
  text-align: center;
  cursor: pointer;
}

body.is-ain-terms-open {
overflow: hidden;
}

#pcBlockedSection img.qr {
width : 50%;
	margin: 30px auto 0;
}
