/* ==============================================
   MOBILE-FIRST RESPONSIVE CSS
   Reorganized for proper mobile-first structure
   ============================================== */

/* ==============================================
   BASE STYLES (MOBILE DEFAULT)
   ============================================== */

/* Box-sizing fix for all elements */
*, *::before, *::after {
  box-sizing: border-box;
}

/* Smooth scroll and anchor link offset for mobile */
html {
  scroll-behavior: smooth;
}

/* Mobile anchor link offset to prevent content being cut off by header */
@media (max-width: 767px) {
  html {
    scroll-padding-top: 80px !important;
  }
  
  /* Additional specific targeting for result sections */
  #result-a,
  #result-b,
  #result-c {
    scroll-margin-top: 40px;
  }
}

.top {
  display: grid;
  justify-items: center;
  align-items: start;
  width: 100%;
  margin: 0 auto;
  min-height: 100vh;
  height: 100%;
}

/* PC Logo, Menu and Entry Button - hide on mobile by default */
.pc-logo,
.pc-menu,
.pc-entry-btn {
  display: none;
}

.top .div {
  background-color: #ffffff;
  width: 100%;
  position: relative;
}

.top .frame {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  position: absolute;
  top: 50px;
  left: 0;
  right: 0;
}

.top .header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 80px;
  padding: 12px 16px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.top .div-16{
  width: 100%;
  max-width: 500px;
}

.top .card{
  width: 100%;
  max-width: 500px;
}

.top .list-card-result{
  width: 100%;
  max-width: 500px;
}

.top .header-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  cursor: pointer;
  pointer-events: auto;
  z-index: 1001;
}

.top .logo {
  width: 102px;
  height: 22px;
}

.top .element {
  width: fit-content;
  font-family: "Outfit", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 0.875rem;
  line-height: 24px;
  
  margin: auto;
}

.top .text-wrapper {
  font-weight: 600;
  color: #e71d0a;
  letter-spacing: 0.6px;
}

.top .span {
  font-weight: 600;
  color: #e71d0a;
  letter-spacing: 0.6px;
}

.top .text-wrapper-2 {
  font-weight: 600;
  color: #e71d0a;
  letter-spacing: 0.6px;
}

.top .header-menu-btn-list {
  right: 48px;
  position: relative;
  flex: 0 0 auto;
}

.top .btn-entry-header {
  justify-content: center;
  gap: 10px;
  padding: 8px 26px;
  background: linear-gradient(
    180deg,
    rgba(255, 44, 25, 1) 0%,
    rgba(220, 21, 3, 1) 100%
  );
  box-shadow: 6px 6px 8px #e71d0a30;
  display: flex;
  align-items: center;
  position: relative;
  border-radius: 100px;
}

.top .text-wrapper-3 {
  font-family: var(--font-primary);
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-weight: 600;
  color: #ffffff;
  font-size: 1.2rem;
  letter-spacing: 0;
  line-height: 40px;
  
}

.top .menu {
  display: flex;
  flex-direction: column;
  width: 31px;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  cursor: pointer;
  z-index: 9999999;  /* Highest z-index for menu button */
}

.top .rectangle {
  position: relative;
  width: 31px;
  height: 2px;
  background-color: #23232a;
  transition: all 0.3s ease;
}

.top .mv {
  position: relative;
  width: 100%;
  height: auto;
}

.top .btn-entry-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 10px 20px 35px 20px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  background-color: #ffffff;
}

.top .frame-2 {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
  margin-left: -0.50px;
  margin-right: -0.50px;
}

.top .line {
  position: relative;
  width: 8.59px;
  height: 18.09px;
  object-fit: cover;
}

.top .text-wrapper-4 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.5vw;
  letter-spacing: 0.32px;
  line-height: 20.8px;
  
}

.top .btn-entry-main {
  justify-content: flex-end;
  gap: 16px;
  padding: 24px 20px 25px 51px;
  align-self: stretch;
  width: 100%;
  max-width: 350px;
  margin: auto;
  flex: 0 0 auto;
  box-shadow: 8px 8px 20px #e71d0a4c;
  background: linear-gradient(
    180deg,
    rgba(255, 44, 25, 1) 0%,
    rgba(220, 21, 3, 1) 100%
  );
  display: flex;
  align-items: center;
  position: relative;
  border-radius: 100px;
  transition: all 0.3s ease;
  cursor: pointer;
  text-decoration: none;
}

.top .btn-entry-main:hover {
  box-shadow: 12px 12px 25px #e71d0a66;
}

.top .btn-entry-main:hover .arrow {
  transform: translateX(2px);
}

.top .text-wrapper-5 {
  position: relative;
  width: fit-content;
  margin-top: -2.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 1.25rem;
  letter-spacing: 0;
  line-height: 20px;
  
}

.top .group {
  position: absolute;
  width: 85px;
  height: 83px;
  top: -7px;
  left: -7px;
}

.top .overlap-group {
  position: relative;
  width: 83px;
  height: 83px;
  background-image: url(../img/vector-1.svg);
  background-size: 100% 100%;
}

.top .text-wrapper-6 {
  position: absolute;
  width: 43px;
  top: 28px;
  left: 20px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #e71d0a;
  font-size: 1.25rem;
  text-align: center;
  letter-spacing: 0.80px;
  line-height: 26px;
  
}

.top .arrow {
  position: relative;
  width: 15px;
  height: 12px;
  background-image: url(../img/arrow.svg);
  background-size: 100% 100%;
  transition: transform 0.3s ease;
}

.top .section-worries {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 27px;
  padding: 0px 15px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  background-color: #ffffff;
}

.top .worries {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  padding: 26px 26px 36px;
  position: relative;
  align-self: stretch;
  width: 100%;
  max-width: 420px;
  margin: auto;
  flex: 0 0 auto;
  background-color: #e5e5e5;
  border-radius: 20px;
}

.top .title-worries {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 19px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .frame-wrapper {
  position: relative;
  width: 98%;
  height: 42.88px;
}

.top .frame-3 {
  display: flex;
  height: 43px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px;
  position: relative;
  border-radius: 100px;
  box-shadow: 6px 6px 8px #90acc629;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(246, 246, 246, 1) 100%
  );
}

.top .text-wrapper-7 {
  width: fit-content;
  margin-top: -0.06px;
  letter-spacing: 0.32px;
  line-height: 20.8px;
  
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1rem;
}

.top .vector {
  position: absolute;
  width: 22px;
  height: 9px;
  top: 42px;
  left: 50%;
  transform: translateX(-50%);
}

.top .h-worries * {
  white-space: normal;
}

.top .p {
  top: 0;
  left: 0;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 1.5rem;
  letter-spacing: 0.96px;
  line-height: 31.2px;
}

.top .text-wrapper-8 {
  font-weight: 700;
  color: #23232a;
  letter-spacing: 0.23px;
}

.top .text-wrapper-9 {
  font-weight: 700;
  color: #e71d0a;
  letter-spacing: 0.23px;
}

.top .worry-list {
  align-items: flex-start;
  gap: 12px;
  align-self: stretch;
  width: 100%;
  display: flex;
  flex-direction: column;
  flex: 0 0 auto;
  list-style: none;
  margin: 0;
  padding: 0;
}

.top .worry-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-bottom: 1px dashed #ffffff;
  padding-bottom: 12px;
}

.top .worry-item::before,
.top .list-item::before {
  content: "";
  display: block;
  width: 20.02px;
  height: 20.06px;
  background-image: url("../img/icon.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
  margin-left: -0.02px;
}

.top .list-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-bottom: 1px dashed #d7d9da;
  padding-bottom: 12px;
}

.top .list-item * {
  white-space: normal;
}

.top .list-item:last-child,
.div-2 > .list-item:last-child {
  border-bottom: none;
  padding-bottom: 0px;
  margin-bottom: 0px;
}

.div-2 > .list-item{
  margin-bottom: 12px;
}
.top .frame-4 {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 0px 0px 12px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  border-color: #ffffff;
}

.top .icon-check {
  position: relative;
  width: 20.02px;
  height: 20.06px;
  margin-left: -0.02px;
}

.top .div-3 {
  align-items: flex-start;
  gap: 2px;
}

.top .div-wrapper {
  display: inline;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 5px 6px;
  flex: 0 0 auto;
  background-color: #0662b9;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 22.4px;
  
}

.top .text-wrapper-10 {
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 22.4px;
  
}

.top .text-wrapper-11 {
  display: inline;
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 22.4px;
  
}

.top .div-4 {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .img {
  position: absolute;
  width: 120px;
  height: auto;
  bottom: 0px;
  right: 3px;
}

.top .div-5 {
  position: relative;
  width: 98%;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 1.5rem;
  text-align: center;
  letter-spacing: 0.80px;
  line-height: 38px;
  
}

.top .text-wrapper-12 {
  font-weight: 700;
  color: #23232a;
  letter-spacing: 0.16px;
  line-height: 32px;
}

.top .text-wrapper-13 {
  font-weight: 700;
  color: #0662b9;
  letter-spacing: 0.16px;
  line-height: 32px;
}

.top .worries-bottom {
  width: 100%;
  height: auto;
}

.top .section-reason {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 50px;
  padding: 40px 15px 0px;
  position: relative;
  align-self: stretch;
  width: 100%;
  margin: auto;
  flex: 0 0 auto;
  background-color: #0662b9;
}

.top .reason {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
}

.top .frame-5 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0px 14px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -0.62px;
  background-color: #ffffff;
  transform: skewX(-14deg);
}

.top .div-6 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 42px;
  
}

.top .text-wrapper-14 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.75rem;
  letter-spacing: 0;
  line-height: 42px;
  
}

.top .text-wrapper-15 {
  font-size: 1rem;
  line-height: 24px;
  
}

.top .element-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0px 14px;
  position: relative;
  flex: 0 0 auto;
  margin-bottom: -0.71px;
  background-color: #ffffff;
  transform: skewX(-14deg);
}

.top .element-2 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  margin-left: -0.12px;
  margin-right: -0.12px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 2rem;
  text-align: left;
  letter-spacing: 0;
  line-height: 48px;
}

.top .text-wrapper-16 {
  font-weight: 700;
  color: #23232a;
}

.top .text-wrapper-17 {
  font-weight: 700;
  color: #e71d0a;
}

.top .list-reason {
  align-items: center;
  gap: 50px;
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.top .card {
  display: flex;
  flex-direction: column;
  max-width: 440px;
  width: 98%;
  align-items: center;
  gap: 10px;
  position: relative;
  border-radius: 20px;
  flex: 0 0 auto;
  box-shadow: var(--card-10);
}

.top .reason-2 {
  gap: 25px;
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  padding: 45px 30px 35px;
  position: relative;
  flex: 0 0 auto;
  background-color: #ffffff;
  border-radius: 20px;
}

.top .main {
  display: flex;
  flex-direction: column;
  width: 98%;
  max-width: 320px;
  align-items: center;
  gap: 12px;
  position: relative;
  flex: 0 0 auto;
}

.top .h-reason {
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.top .subtitle {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.125rem;
  text-align: center;
  letter-spacing: 0.36px;
  line-height: 18px;
  
}

.top .title {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 36px;
  
  position: relative;
  width: fit-content;
  color: transparent;
  text-align: center;
}

.top .text-wrapper-18 {
  color: #e71d0a;
  letter-spacing: 0.16px;
  line-height: 36.4px;
  
}

.top .text-wrapper-19 {
  color: #23232a;
  letter-spacing: 0;
  line-height: 0.1px;
  
}

.top .img-reason {
  position: relative;
  width: 272.09px;
  height: 206px;
}

.top .overlap-group-2 {
  position: relative;
  width: 272px;
  height: 206px;
}

.top .image-mask {
  position: absolute;
  width: 191px;
  height: 191px;
  top: 4px;
  left: 41px;
  background-color: #fef1f0;
  border-radius: 600px;
}

.top .mask-group-2 {
  position: absolute;
  width: 140px;
  height: auto;
  bottom: 20px;
  left: 64px;
}

.top .group-2 {
  position: absolute;
  width: 98px;
  height: 65px;
  top: 52px;
  left: 12px;
}

.top .group-3 {
  position: absolute;
  width: 97px;
  height: 65px;
  top: 70px;
  left: 173px;
}

.top .group-4 {
  position: absolute;
  width: 131px;
  height: 53px;
  top: 16px;
  left: 75px;
}

.top .container {
  display: flex;
  width: 178px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 8px 10px;
  position: absolute;
  top: 169px;
  left: 47px;
  background-color: #e71d0a;
  border-radius: 30px;
}

.top .caption {
  margin-top: -1.00px;
  color: #ffffff;
  text-align: center;
  letter-spacing: 0;
  line-height: 20.8px;
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1rem;
}

.top .annotation {
  position: relative;
  max-width: 293px;
  width: 98%;
  height: 16px;
  margin-right: -2.00px;
}

.top .annotation-2 {
  position: absolute;
  top: 0;
  left: 0;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 0.75rem;
  letter-spacing: 0;
  line-height: 15.6px;
}

.top .list-bottom {
  align-items: center;
  gap: 18px;
  align-self: stretch;
  width: 100%;
  margin: auto;
  display: flex;
  flex-direction: column;
  position: relative;
  flex: 0 0 auto;
}

.top .readon {
  display: inline-flex;
  align-items: flex-start;
  gap: 3px;
  position: relative;
  flex: 0 0 auto;
}

.top .subtitle-2 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.60px;
  line-height: 19.5px;
  
}

.top .list-reason-2 {
  align-items: flex-start;
  gap: 8px;
  display: flex;
  flex-direction: column;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.top .div-7 {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0px 0px 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  border-color: #d7d9da;
}

.top .icon {
  position: relative;
  width: fit-content;
  margin-top: -0.50px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 0.875rem;
  letter-spacing: 0.56px;
  line-height: 18.2px;
  
}

.top .text-wrapper-20 {
  color: #23232a;
  letter-spacing: 0.08px;
}

.top .text-wrapper-21 {
  color: #f37c21;
  letter-spacing: 0.08px;
}

.top .description {
  width: fit-content;
  margin-top: -0.50px;
  font-weight: 400;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.56px;
  line-height: 18.2px;
  
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .text-wrapper-22 {
  color: #20588f;
  letter-spacing: 0.08px;
}

.top .li-every-other-day {
  display: flex;
  width: 100%;
  max-width: 320px;
  align-items: center;
  gap: 16px;
  position: relative;
}

.top .text-wrapper-23 {
  color: #6d6d74;
  letter-spacing: 0.08px;
}

.top .overlap-group-wrapper {
  position: absolute;
  width: 60px;
  height: 60px;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(../img/mask-group-8.webp);
  background-size: 100% 100%;
}

.top .overlap-group-3 {
  position: relative;
  height: 60px;
  border-radius: 30px;
}

.top .frame-6 {
  display: flex;
  flex-direction: column;
  width: 60px;
  height: 60px;
  align-items: center;
  justify-content: center;
  gap: 2px;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 100px;
}

.top .text-wrapper-24 {
  position: relative;
  width: fit-content;
  font-family: "Outfit", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 0.625rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 10px;
  
}

.top .text-wrapper-25 {
  font-weight: 400;
  font-size: 1.5rem;
  letter-spacing: 0;
  line-height: 24px;
  
  position: relative;
  width: fit-content;
  font-family: "Outfit", Helvetica;
  color: #ffffff;
  text-align: center;
}

.top .ellipse {
  position: absolute;
  width: 60px;
  height: 60px;
  top: 0;
  left: 0;
  border-radius: 30px;
  border: 2px solid;
  border-color: #ffffff;
}

.top .reason-3 {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 25px;
  padding: 45px 30px 35px;
  position: relative;
  background-color: #ffffff;
  border-radius: 20px;
}

.top .main-reason {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  position: relative;
  flex: 0 0 auto;
}

.top .reason-4 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.top .title-2 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 28px;
  
  position: relative;
  width: fit-content;
  color: transparent;
  text-align: center;
}

.top .text-wrapper-26 {
  color: #23232a;
  letter-spacing: 0;
  line-height: 36.4px;
  
}

.top .img-reason-2 {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 320px;
  align-items: center;
  gap: 12px;
  position: relative;
  flex: 0 0 auto;
}

.top .fukidashi-worries {
  position: relative;
  width: 1px;
  height: 1px;
}

.top .img-reason-3 {
  position: relative;
  width: 100%;
  height: 159.16px;
  margin-right: -4.00px;
}

.top .group-5 {
  position: absolute;
  width: 85%;
  max-width: 281px;
  height: 22px;
  top: 0;
  left: 12%;
}

.top .overlap {
  position: absolute;
  width: 88%;
  max-width: 286px;
  height: 136px;
  top: 23px;
  left: 11%;
}

.top .vector-2 {
  position: absolute;
  width: 49.8%;
  max-width: 146px;
  height: 136px;
  top: 0;
  opacity: 0.5;
  left: 49%;
}

.top .vector-3 {
  position: absolute;
  width: 50%;
  max-width: 142px;
  height: 136px;
  top: 0;
  left: 0.5%;
}

.top .container-2 {
  display: flex;
  width: 82%;
  max-width: 234px;
  align-items: center;
  gap: 19.4%;
  position: absolute;
  top: 0;
  left: 17%;
}

.top .line-4 {
  position: relative;
  width: 1px;
  height: 136px;
}

.top .line-5 {
  position: relative;
  width: 1px;
  height: 136px;
  object-fit: cover;
}

.top .line-6 {
  position: relative;
  width: 1px;
  height: 136px;
  margin-right: -0.45px;
  object-fit: cover;
}

.top .group-6 {
  position: absolute;
  width: 50%;
  max-width: 142px;
  height: 34px;
  top: 20px;
  left: 0.5%;
}

.top .overlap-group-4 {
  width: 100%;
  max-width: 141px;
  height: 34px;
  background-image: url(../img/vector-8.svg);
  background-size: 100% 100%;
}

.top .frame-7 {
  display: flex;
  width: 80px;
  height: 20px;
  align-items: flex-end;
  justify-content: center;
  position: relative;
  top: 6px;
  left: 28px;
}

.top .text-wrapper-27 {
  position: relative;
  width: 28px;
  height: 16px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 0.875rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 14px;
  
}

.top .text-wrapper-28 {
  margin-top: -1.00px;
  font-weight: 500;
  font-size: 1.25rem;
  letter-spacing: 0.40px;
  line-height: 20px;
  
  position: relative;
  width: fit-content;
  font-family: "Outfit", Helvetica;
  color: #ffffff;
  text-align: center;
}

.top .overlap-wrapper {
  position: absolute;
  width: 50%;
  max-width: 142px;
  height: 34px;
  top: 84px;
  left: 0.5%;
}

.top .text-wrapper-29 {
  position: relative;
  width: 28px;
  height: 16px;
  margin-left: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 0.875rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 14px;
  
}

.top .text-wrapper-30 {
  position: relative;
  width: 28px;
  height: 16px;
  margin-right: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 0.875rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 14px;
  
}

.top .group-7 {
  position: absolute;
  width: 49%;
  max-width: 141px;
  height: 34px;
  top: 84px;
  left: 50%;
  background-image: url(../img/vector-8.svg);
  background-size: 100% 100%;
}

.top .vector-4 {
  position: absolute;
  width: 2px;
  height: 136px;
  top: 0;
  left: 0;
}

.top .group-8 {
  position: absolute;
  width: 46%;
  max-width: 133px;
  height: 46px;
  top: 45px;
  left: 53%;
}

.top .group-9 {
  position: absolute;
  width: 36%;
  max-width: 104px;
  height: 42px;
  top: 10px;
  left: 50%;
}

.top .icon-2 {
  position: absolute;
  width: 29px;
  top: 51px;
  left: 0;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #f37c21;
  font-size: 0.875rem;
  text-align: center;
  letter-spacing: 0.56px;
  line-height: 18.2px;
  
}

.top .icon-3 {
  position: absolute;
  width: 27px;
  top: 107px;
  left: 1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 0.8125rem;
  letter-spacing: 0.78px;
  line-height: 16.9px;
  
}

.top .text-wrapper-31 {
  color: #20588f;
  letter-spacing: 0.10px;
}

.top .text-wrapper-32 {
  color: #6d6d74;
  letter-spacing: 0.10px;
}

.top .container-3 {
  display: flex;
  width: 100%;
  max-width: 320px;
  align-items: center;
  padding: 7px 14px;
  gap: 8px;
  position: relative;
  border-radius: 10px;
  border: 2px solid;
  border-color: #d7d9da;
  justify-content: space-between;
}

.top .caption-2 {
  color: transparent;
  letter-spacing: 0.32px;
  line-height: 23.2px;
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1rem;
}

.top .text-wrapper-33 {
  color: #23232a;
  letter-spacing: 0.05px;
}

.top .text-wrapper-34 {
  color: #e71d0a;
  font-size: 1.125rem;
  letter-spacing: 0.06px;
  line-height: 26.1px;
  
}

.top .text-wrapper-35 {
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0.06px;
  line-height: 26.1px;
  
}

.top .group-10 {
  position: relative;
  width: 110px;
  height: 70px;
  margin-right: -4.00px;
}

.top .list-bottom-2 {
  gap: 15px;
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  position: relative;
}

.top .subtitle-wrapper {
  position: relative;
  width: 97px;
  height: 21px;
}

.top .subtitle-3 {
  position: absolute;
  top: 0;
  left: 0;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 20.8px;
  
}

.top .list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

/* General list styling */
.top ul {
  width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
}

.top .icon-4 {
  position: relative;
  width: 18.02px;
  height: 18.06px;
  margin-bottom: -0.06px;
  margin-left: -0.02px;
}

.top .description-2 {
  width: fit-content;
  margin-top: -1.00px;
  font-weight: 700;
  color: #e71d0a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 18.2px;
  
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .li-monthly-income {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.top .img-2 {
  position: relative;
  width: 18.02px;
  height: 18.06px;
  margin-left: -0.02px;
}

.top .div-wrapper-2 {
  display: flex;
  align-items: flex-start;
  gap: 2px;
  position: relative;
}

.top .description-3 {
  margin-top: -1.00px;
  margin-right: -3.00px;
  font-weight: 400;
  color: transparent;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 18.2px;
  
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .text-wrapper-36 {
  color: #23232a;
}

.top .title-3 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1.75rem;
  letter-spacing: 0.56px;
  line-height: 36.4px;
  
  position: relative;
  width: fit-content;
  color: transparent;
  text-align: center;
}

.top .text-wrapper-37 {
  color: #23232a;
  letter-spacing: 0.16px;
}

.top .text-wrapper-38 {
  color: #e71d0a;
  letter-spacing: 0.16px;
}

.top .list-bottom-3 {
  gap: 12px;
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  position: relative;
}

.top .div-9 {
  width: fit-content;
  margin-top: -1.00px;
  font-weight: 400;
  color: transparent;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 18.2px;
  
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .container-4 {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  margin-bottom: -2.00px;
}

.top .title-4 {
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.48px;
  line-height: 24px;
  
  position: relative;
  width: fit-content;
  color: transparent;
  text-align: center;
}

.top .text-wrapper-39 {
  color: #23232a;
  letter-spacing: 0.12px;
  line-height: 33.6px;
  
}

.top .text-wrapper-40 {
  font-family: var(--font-japanese);
  color: #e71d0a;
  letter-spacing: 0.12px;
  line-height: 1.6;
  
}

.top .list-bottom-4 {
  gap: 12px;
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  position: relative;
}

.top .div-10 {
  width: fit-content;
  margin-top: -1.00px;
  font-weight: 400;
  color: transparent;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .div-11 {
  margin-top: -1.00px;
  margin-right: -3.00px;
  font-weight: 400;
  color: transparent;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
  
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .title-5 {
  margin-top: -1.00px;
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 24px;
  
}

.text-wrapper-41 {
  font-family: var(--font-japanese);
  font-size: 1.75rem;
  transform: skewX(-14deg);
  font-weight: 600;
  color: #23232a;
  letter-spacing: 0.23px;
}

.reason-4-text{
  font-family: var(--font-primary);
  font-size: 1.75rem;
}

.top .text-wrapper-42 {
  font-family: var(--font-primary);
  font-weight: 600;
  color: var(--color-secondary);
  letter-spacing: 0.23px;
  font-size: 1.125rem;
}

.top .div-12 {
  width: 100%;
  align-items: flex-start;
  gap: 12px;
  display: flex;
  flex-direction: column;
  position: relative;
  flex: 0 0 auto;
}

.top .container-5 {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.top .btn-entry-area-2 {
  width: 100%;
  padding: 0px 10px 50px 10px;
  flex: 0 0 auto;
  margin: 0 auto;
  background-color: #0662b9;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: relative;
}

.top .text-wrapper-44 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: var(--font-primary);
  font-weight: 700;
  color: var(--color-secondary);
  letter-spacing: 0.32px;
  line-height: 20.8px;
}

.top .reason-bottom {
  width: 100%;
  height: auto;
}

.top .section-diagnosis {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 15px 0px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  background-color: #ffffff;
}

.top .diagnosis {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 12px;
  position: relative;
  flex: 0 0 auto;
}

.top .text-wrapper-45 {
  font-family: var(--font-japanese);
  font-weight: 600;
  font-size: 1rem;
  text-align: left;
  letter-spacing: 0.72px;
  line-height: 24px;
  margin-top: -4px;
}

.top .text-wrapper-46 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 1.12px;
  line-height: 38px;
}

.top .diagnosis-options {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  margin: auto;
  flex: 0 0 auto;
  list-style: none;
  padding: 0;
}

.top .btn-diagnosis {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 18px 20px;
  position: relative;
  flex: 0 0 auto;
  background-color: #ffffff;
  border-radius: 100px;
  border: 2px solid;
  border-color: #0662b9;
  box-shadow: var(--card-blue);
  transition: all 0.3s ease;
  cursor: pointer;
  text-decoration: none;
}

.top .btn-diagnosis:hover {
  background-color: #f0f6fb;
  box-shadow: 16px 16px 15px rgba(202, 215, 227, 0.4);
}

.top .btn-diagnosis:hover .arrow-2 {
  transform: translateY(2px);
}

.top .diagnosis-title{
  font-family: var(--font-japanese);
  font-size: 1.125rem;
  color: #0662b9;
  font-weight: 600;
  margin-bottom: 10px;
  transform: skewX(-14deg);
}

.top .text-wrapper-47 {
  font: var(--font-japanese);
  font-weight: 700;
  font-size: 1.125rem;
  letter-spacing: 0;
  line-height: 26px;
  color: #e71d0a;
}

.top .text-wrapper-48 {
  position: relative;
  width: 220px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.0625rem;
  letter-spacing: 0;
  line-height: 22.1px;
}

.top .arrow-2 {
  position: relative;
  width: 14px;
  height: 8px;
  transition: transform 0.3s ease;
}

.top .diagnosis-req-bottom {
  width: 100%;
  height: auto;
}

.top .section-result {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  gap: 38px;
  padding: 50px 15px 0px;
  position: relative;
  flex: 0 0 auto;
  background-color: #c1d8ee;
}

.top .list-card-result {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 48px;
  position: relative;
  align-self: stretch;
  width: 100%;
  max-width: 440px;
  margin: auto;
  flex: 0 0 auto;
}

.top .card-result-a {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 26px;
  padding: 40px 30px 25px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 20px;
  box-shadow: var(--card-blue);
}

.top .title-result-a {
  display: flex;
  width: 210px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 8px 0px;
  position: absolute;
  top: -18px;
  background-color: #0662b9;
  border-radius: 100px;
  border: 1px solid;
  border-color: #ffffff;
}

.result-text{
  color: #f37c21;
}

.top .text-wrapper-49 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 1.125rem;
  text-align: center;
  letter-spacing: 0.72px;
  line-height: 18px;
}

.top .result-a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  position: relative;
  flex: 0 0 auto;
}

.top .div-14 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 33.8px;
}

.top .text-wrapper-50 {
  font-family: var(--font-japanese);
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: 26px;
  color: #23232a;
}

.top .text {
  position: relative;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 18.2px;
}

.top .text-2 {
  position: relative;
  margin-top: -1.00px;
  margin-right: -3.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
}

.top .container-6 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  transition: all 0.3s ease;
  cursor: pointer;
  text-decoration: none;
}

.top .container-6:hover .link-text {
  text-decoration: none;
}

.top .link-text {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #0662b9;
  font-size: 0.875rem;
  text-align: center;
  text-decoration: underline;
  letter-spacing: 0;
  line-height: 18.2px;
  text-decoration: underline;
}

.top .arrow-3 {
  position: relative;
  width: 10px;
  height: 6px;
}

.top .text-wrapper-51 {
  color: #20588f;
}

.top .text-3 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.4;
}

.top .text-4 {
  position: relative;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
}

.top .div-15 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  margin-left: -26.00px;
  margin-right: -26.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 33.8px;
}

.top .text-wrapper-52 {
  color: #6d6d74;
}

.top .text-container {
  display: flex;
  align-items: flex-start;
  gap: 2px;
  position: relative;
}

.top .text-5 {
  position: relative;
  margin-top: -1.00px;
  margin-right: -3.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
}

.top .btn-entry-area-3 {
  padding: 10px 10px 50px 10px;
  align-self: stretch;
  width: 100%;
  background-color: #c1d8ee;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: relative;
}

.top .bottom-result {
  position: relative;
  width: 100%;
  height: 20px;
  background-color: #c1d8ee;
}

.top .rectangle-2 {
  height: 20px;
  background-color: #ffffff;
  border-radius: 20px 20px 0px 0px;
}

.top .section-access {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 25px;
  padding: 30px 20px;
  position: relative;
  flex: 0 0 auto;
  background-color: #ffffff;
}

.top .access {
  position: relative;
  width: 222.89px;
  height: 43.66px;
}

.top .text-wrapper-53 {
  position: absolute;
  top: -1px;
  left: 5px;
  transform: skewX(-14deg);
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 1.12px;
  line-height: 44.8px;
}

.top .div-16 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  position: relative;
  align-self: stretch;
  width: 100%;
  max-width: 420px;
  margin: auto;
  flex: 0 0 auto;
}

.top .map {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 62.86%;
  overflow: hidden;
}

.top .map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.top .list-access {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .element-MAP {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.60px;
  line-height: 22.5px;
}

.top .text-wrapper-54 {
  letter-spacing: 0.09px;
}

.top .text-wrapper-55 {
  letter-spacing: 0.09px;
  text-decoration: underline;
}

.top .text-wrapper-56 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.60px;
  line-height: 19.5px;
}

.top .bottom-access {
  position: relative;
  width: 100%;
  height: 20px;
  background-color: #e0ecf7;
  transform: rotate(-180deg);
}

.top .section-milight {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 40px;
  padding: 45px 15px 0px;
  position: relative;
  flex: 0 0 auto;
  background-color: #e0ecf7;
}

.top .milight {
  display: flex;
  flex-direction: column;
  width: 294.77px;
  align-items: center;
  gap: 14px;
  position: relative;
  flex: 0 0 auto;
}

.top .image {
  position: relative;
  width: 89px;
  height: 89px;
  object-fit: cover;
}

.top .div-17 {
  position: relative;
  align-self: stretch;
  transform: skewX(-14deg);
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 1.12px;
  line-height: 28px;
}

.top .text-wrapper-57 {
  color: #23232a;
  letter-spacing: 0.31px;
}

.top .text-wrapper-58 {
  color: #e71d0a;
  letter-spacing: 0.31px;
}

.top .card-milight {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  padding: 30px 30px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 20px;
  box-shadow: var(--card-blue);
}

.top .text-wrapper-59 {
  top: 0;
  left: 0;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0.96px;
  line-height: 1.4;
}

.top .cantents {
  flex: 1;
  flex-grow: 1;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
  position: relative;
  width: 100%;
}

.top .cantents picture,
.top .cantents-milight picture{
  width: 100%;
  height: auto;
}

.top .list-milight {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  gap: 12px;
  position: relative;
  flex: 1;
  flex-grow: 1;
}

.top .frame-8 {
  display: flex;
  width: 100%;
  max-width: 320px;
  align-items: flex-start;
  gap: 8px;
  padding: 0px 0px 12px;
  position: relative;
  flex: 0 0 auto;
  border-bottom-width: 1px;
  border-bottom-style: dashed;
  border-color: #d7d9da;
}

.top .element-3 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
}

.top .frame-9 {
  margin-bottom: -2.00px;
  display: flex;
  width: 100%;
  max-width: 320px;
  height: 19px;
  align-items: flex-start;
  gap: 8px;
  position: relative;
}

.top .card-3 {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding: 30px 30px;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 20px;
  box-shadow: var(--card-blue);
}

.top .div-18 {
  font-family: "Outfit", Helvetica;
  font-weight: 400;
  line-height: 31.2px;
  color: #23232a;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0.96px;
}

.top .text-wrapper-60 {
  font-weight: 600;
  letter-spacing: 0.23px;
}

.top .text-wrapper-61 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  letter-spacing: 0.23px;
}

.top .cantents-milight {
  flex: 0 0 auto;
  width: 100%;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
}

.top .element-4 {
  color: transparent;
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  font-size:1rem;
  letter-spacing: 0;
  line-height: 1.5;
}

.top .frame-10 {
  display: flex;
  width: 100%;
  max-width: 320px;
  height: 19px;
  align-items: flex-start;
  gap: 8px;
  position: relative;
}

.top .text-wrapper-62 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  line-height: 33.6px;
  color: #23232a;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0.96px;
}

.top .element-5 {
  color: #23232a;
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0;
  line-height:1.5;
}

.top .frame-11 {
  display: flex;
  width: 100%;
  max-width: 320px;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.top .element-6 {
  color: #23232a;
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 1.5;
}

.top .btn-entry-area-4 {
  padding: 30px 10px 50px 10px;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  background-color: #e0ecf7;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: relative;
}

.top .overlap-group-5 {
  position: relative;
  width: 83px;
  height: 83px;
  background-image: url(../img/vector-14.svg);
  background-size: 100% 100%;
}

.top .rectangle-wrapper {
  position: relative;
  width: 100%;
  height: 20px;
  background-color: #e0ecf7;
}

.top .rectangle-3 {
  height: 20px;
  background-color: #0662b9;
  border-radius: 20px 20px 0px 0px;
}

.top .section-flow {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 40px;
  padding: 40px 25px;
  position: relative;
  flex: 0 0 auto;
  background-color: #0662b9;
}

.top .frame-12 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .flow {
  position: relative;
  width: 296.32px;
  height: 81.5px;
}

.top .section-title {
  position: absolute;
  top: -1px;
  left: 10px;
  transform: skewX(-14deg);
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 42px;
}

.top .text-wrapper-63 {
  color: #ffdd64;
}

.top .text-wrapper-64 {
  color: #ffffff;
}

.top .div-19 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 25px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .subtitle-4 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 1rem;
  text-align: center;
  letter-spacing: 0.64px;
  line-height: 25.6px;
}

.top .list-flow {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 340px;
  align-items: flex-start;
  gap: 19px;
  position: relative;
  flex: 0 0 auto;
}

.top .step-flow {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  gap: 10px;
}

.top .container-wrapper {
  position: relative;
  width: 47px;
  height: 134px;
  background-image: url(../img/rectangle-367-2.svg);
  background-size: 100% 100%;
}

.top .container-7 {
  position: relative;
  width: 30px;
  height: 97px;
  top: 11px;
  left: 11px;
}

.top .overlap-group-6 {
  position: relative;
  width: 24px;
  height: 97px;
}

.top .day {
  position: absolute;
  top: 0;
  left: 5px;
  font-family: "Outfit", Helvetica;
  font-weight: 600;
  color: #23232a;
  font-size: 1.5rem;
  text-align: center;
  letter-spacing: 0.96px;
  line-height: 28.8px;
}

.top .month {
  top: 45px;
  position: absolute;
  left: 0;
  font-family: "Outfit", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1.5rem;
  text-align: center;
  letter-spacing: 0.96px;
  line-height: 24px;
}

.top .text-wrapper-65 {
  font-weight: 600;
  letter-spacing: 0.23px;
  line-height: 0.1px;
}

.top .text-wrapper-66 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  letter-spacing: 0.23px;
  line-height: 26.4px;
}

.top .date-range {
  position: absolute;
  top: 25px;
  left: 2px;
  transform: rotate(90deg);
  color: #23232a;
  font-size: 1.25rem;
  text-align: center;
  letter-spacing: 0.80px;
  line-height: 24.0px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
}

.top .container-8 {
  display: flex;
  flex-direction: column;
  width: 278px;
  align-items: flex-start;
  gap: 10px;
  padding: 20px;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
}

.top .step {
  align-self: stretch;
  margin-top: -1.00px;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.64px;
  line-height: 16px;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  color: #23232a;
}

.top .step-2 {
  align-self: stretch;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.64px;
  line-height: 16px;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  color: #23232a;
}

.top .flow-2 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  gap: 8px;
}

.top .container-9 {
  position: relative;
  width: 47px;
  height: 170px;
  background-image: url(../img/rectangle-367.svg);
  background-size: 100% 100%;
}

.top .month-wrapper {
  position: relative;
  width: 27px;
  height: 52px;
  top: 50px;
  left: 11px;
}

.top .month-2 {
  top: 0;
  position: absolute;
  left: 0;
  font-family: "Outfit", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1.5rem;
  text-align: center;
  letter-spacing: 0.96px;
  line-height: 24px;
}

.top .container-10 {
  display: flex;
  flex-direction: column;
  width: 278px;
  align-items: flex-start;
  gap: 16px;
  padding: 20px;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
}

.top .date-range-2 {
  position: relative;
  width: fit-content;
  margin: -1.00px 0px 8px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #0662b9;
  font-size: 1.125rem;
  letter-spacing: 0.72px;
  line-height: 18px;
}

.top .step-3 {
  width: fit-content;
  font-weight: 400;
  font-size: 1rem;
  letter-spacing: 0.64px;
  line-height: 1.4;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  color: #23232a;
}

.top .container-11 {
  position: relative;
  width: 47px;
  height: 98px;
  background-image: url(../img/rectangle-367-1.svg);
  background-size: 100% 100%;
}

.top .container-12 {
  position: relative;
  width: 26px;
  height: 52px;
  top: 16px;
  left: 11px;
}

.top .container-13 {
  display: flex;
  width: 278px;
  align-items: center;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
}

.top .container-14 {
  display: flex;
  width: 50%;
  flex-direction: column;
  align-items: flex-start;
  padding: 20px;
  position: relative;
}

.top .date-range-3 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  margin-right: -40.00px;
  color: #0662b9;
  font-size: 1.125rem;
  letter-spacing: 0.72px;
  line-height: 28.8px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
}

.top .step-4 {
  width: fit-content;
  margin-right: -30.00px;
  font-weight: 700;
  font-size: 1.125rem;
  letter-spacing: 0.72px;
  line-height: 28.8px;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  color: #23232a;
}

.top .img-4 {
  position: relative;
  width: 107.38px;
  height: 51.19px;
  margin-right: 20px;
}

.top .container-15 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  position: relative;
  flex: 0 0 auto;
  max-width: 440px;
}

.top .h-flow {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
}

.top .subtitle-5 {
  position: relative;
  width: fit-content;
  margin-top: -1.49px;
  transform: skewX(-14deg);
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 1.375rem;
  text-align: center;
  letter-spacing: 0.88px;
  line-height: 33px;
}

.top .subtitle-6 {
  position: relative;
  width: fit-content;
  transform: skewX(-14deg);
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #FFDD64;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0.88px;
  line-height: 40px;
}

.top .description-4 {
  align-self: stretch;
  font-weight: 400;
  color: #ffffff;
  font-size: 1rem;
  letter-spacing: 0.64px;
  line-height: 25.6px;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .btn-entry-area-5 {
  width: 100%;
  max-width: 100%;
  padding: 0px 0px 40px 0px;
  flex: 0 0 auto;
  background-color: #0662b9;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: relative;
  margin: 0 auto;
}

.top .bottom-flow {
  position: relative;
  width: 100%;
  height: 20px;
  background-color: #e0ecf7;
  transform: rotate(180deg);
}

.top .section-driver-voice {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 23px;
  padding: 50px 20px;
  position: relative;
  flex: 0 0 auto;
  background-color: #e0ecf7;
}

.top .driver {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 40.75px;
  margin-right: -2.00px;
}

.top .div-20 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  transform: skewX(-14deg);
  color: transparent;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 0;
  line-height: 42px;
}

.top .text-wrapper-67 {
  color: #e71d0a;
}

.top .frame-13 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 29px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  max-width: 440px;
  margin: auto;
}

.top .text-wrapper-68 {
  position: relative;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0.64px;
  line-height: 25.6px;
}

.top .text-wrapper-69 {
  width: fit-content;
  font-weight: 700;
  color: #23232a;
  font-size: 1.125rem;
  letter-spacing: 0.36px;
  line-height: 18px;
  position: relative;
}

.top .youtube {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  flex: 0 0 auto;
  position: relative;
  align-self: stretch;
  width: 100%;
  max-width: 390px;
  margin: auto;
}

.youtube-title{
  font-size: 0.875rem;
  line-height: 22px;
}

.youtube-title a{
  color: var(--color-dark);
}

.top .youtube-2 {
  position: relative;
  align-self: stretch;
  width: 100%;
}

  .youtube iframe {
    width: 100% ;
    height: auto ;
    aspect-ratio: 16/9;
    display: block;
  }

.top .text-wrapper-70 {
  align-self: stretch;
  font-weight: 400;
  color: #333333;
  font-size: 0.875rem;
  letter-spacing: 0.84px;
  line-height: 21px;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
}

.top .youtube-3 {
  height: 196.29px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.top .section-faq {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  gap: 45px;
  padding: 60px 20px 60px;
  flex: 0 0 auto;
  background-color: #ffffff;
}

.top .text-wrapper-71 {
  position: absolute;
  top: -1px;
  left: 4px;
  transform: skewX(-14deg);
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1.75rem;
  text-align: center;
  letter-spacing: 1.12px;
  line-height: 36.4px;
}

.faq-accordion {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  list-style: none;
  margin: 0;
  padding: 0;
}

.faq-item {
  width: 100%;
  max-width: 420px;
  display: flex;
  flex-direction: column;
  margin: 0px auto;
}

.faq-question {
  width: 100%;
  background: transparent;
  border: none;
  padding: 16px 14px;
  border-radius: 10px;
  border: 1px solid var(--color-gray);
  cursor: pointer;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.3s ease;
}

.faq-question:hover {
  background-color: #f8f8f8;
  border-color: var(--color-primary);
  box-shadow: 6px 6px 8px rgba(0, 39, 75, 0.1);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.faq-item[aria-expanded="true"] .faq-answer {
  max-height: 200px;
  margin:24px 0px 20px;
  padding-left: 14px;
  font-size: 1.25rem;
}

.faq-item[aria-expanded="true"] .btn-close .rectangle-4::before {
  transform: rotate(90deg);
}

.btn-close .rectangle-4 {
  transition: transform 0.3s ease;
}

.top .frame-16 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 23px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .list-faq {
  padding: 20px 12px 20px 14px;
  display: flex;
  align-items: center;
  gap: 3px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 10px;
  border: 1px solid;
  border-color: #d7d9da;
  box-shadow: 4px 4px 8px #00264a38;
  justify-content: space-between;
}

.top .faq-text {
  align-items: center;
  display: flex;
  gap: 5px;
  position: relative;
}

.top .icon-q {
  font-family: var(--font-primary);
  display: flex;
  flex-direction: column;
  width: 14px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
}

.top .text-wrapper-72 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  font-family: "Outfit", Helvetica;
  font-weight: 600;
  color: var(--background-600);
  font-size: 1.25rem;
  letter-spacing: 0;
  line-height: 20px;
  
}

.top .text-wrapper-73 {
  position: relative;
  width: 272px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 16px;
}

.top .btn-close {
  position: relative;
  width: 26px;
  height: 26px;
  min-width: 26px;
  min-height: 26px;
  flex-shrink: 0;
  background-color: #0662b9;
  border-radius: 13px;
}

.top .rectangle-4 {
  position: relative;
  width: 10px;
  height: 2px;
  top: 12px;
  left: 8px;
  background-color: var(--text-600);
}

.top .rectangle-4::before {
  content: '';
  position: absolute;
  width: 2px;
  height: 10px;
  top: -4px;
  left: 4px;
  background-color: var(--text-600);
  transition: transform 0.3s ease;
}

.top .frame-17 {
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.top .text-wrapper-74 {
  position: relative;
  width: 17px;
  margin-top: -1.00px;
  font-family: "Outfit", Helvetica;
  font-weight: 600;
  color: var(--background-600);
  font-size: 1.25rem;
  letter-spacing: 0;
  line-height: 20px;
  
}

.top .text-wrapper-75 {
  position: relative;
  width: 308px;
  margin-top: -1.00px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 24.8px;
}

.top .frame-18 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.top .list-faq-2 {
  padding: 18px 12px 18px 14px;
  display: flex;
  align-items: center;
  gap: 3px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 10px;
  border: 1px solid;
  border-color: #d7d9da;
  box-shadow: 4px 4px 8px #00264a38;
}

.top .faq-text-2 {
  align-items: flex-start;
  display: flex;
  gap: 5px;
}

.top .icon-q-2 {
  padding-top: 4px;
}

.top .text-wrapper-76 {
  width: 272px;
  margin-top: -1.00px;
  letter-spacing: 0;
  line-height: 24px;
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #23232a;
  font-size: 1rem;
}

.top .footer {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 352px;
  align-items: flex-start;
  gap: 46px;
  padding: 36px 28px 20px;
  position: relative;
  background-color: #EAEAEA;
  border-radius: 20px 20px 0px 0px;
}

.logo-text{
  font-family: var(--font-japanese);
  font-weight: 600;
  margin-top: 8px;
}

.top .logo-2 {
  display: flex;
  flex-direction: column;
  width: 132px;
  align-items: flex-start;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.top .logo-3 {
  position: relative;
  width: 132px;
  height: 29px;
}

.top .text-wrapper-77 {
  position: relative;
  align-self: stretch;
  font-family: "Noto Sans JP", Helvetica;
  font-weight: 600;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.60px;
  line-height: 19.5px;
}

.company-list {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  flex: 0 0 auto;
  list-style: none;
  margin: 0;
  padding: 0;
}

.company-list li {
  position: relative;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 500;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0;
  line-height: 22.1px;
}

.section-reason .text-wrapper-44,
.section-flow .text-wrapper-44 {
  font-family: var(--font-japanese);
  color: white;
  font-size: 1.5vw;
  font-weight: 600;
  position: relative;
}

.frame-2 > .text-wrapper-44::before,
.frame-2 > .text-wrapper-4::before {
  content: '';
  position: absolute;
  left: -20px;
  top: 50%;
  width: 20px;
  height: 1px;
  background-color: #23232a;
  transform: translateY(-50%) rotate(60deg);
}

.frame-2 > .text-wrapper-44::after,
.frame-2 > .text-wrapper-4::after {
  content: '';
  position: absolute;
  right: -20px;
  top: 50%;
  width: 20px;
  height: 1px;
  background-color:#23232a;
  transform: translateY(-50%) rotate(-60deg);
}

.section-reason .frame-2 > .text-wrapper-44::after,
.section-flow .frame-2 > .text-wrapper-44::after,
.section-reason .frame-2 > .text-wrapper-44::before,
.section-flow .frame-2 > .text-wrapper-44::before {
  background-color: #fff;
}

.top .text-wrapper-78 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  font-family: "Noto Sans JP", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.60px;
  line-height: 19.5px;
}

.top .text-wrapper-79 {
  position: relative;
  align-self: stretch;
  font-family: "Noto Sans JP", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 0.9375rem;
  letter-spacing: 0.60px;
  line-height: 19.5px;
}

.top .text-wrapper-80 {
  position: relative;
  align-self: stretch;
  font-family: "Outfit", Helvetica;
  font-weight: 400;
  color: #23232a;
  font-size: 0.75rem;
  letter-spacing: 0.48px;
  line-height: 15.6px;
}

/* Page Top Button */
.page-top-btn {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 60px;
  height: 60px;
  background-color: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(10px);
  border: none;
  border-radius: 50%;
  color: var(--color-dark);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: 0.75rem;
  font-weight: bold;
  z-index: 1000;
  transition: all 0.3s ease;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.page-top-btn:hover {
  background-color: rgba(255, 255, 255, 0.9);
  transform: translateY(-2px);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.15);
}

.page-top-btn.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.page-top-btn span:first-child {
  font-size: 1rem;
  line-height: 1;
  margin-bottom: 2px;
}

.page-top-btn span:last-child {
  font-size: 0.625rem;
  line-height: 1;
}

/* ==============================================
   VERY SMALL MOBILE (max-width: 375px)
   ============================================== */

@media (max-width: 375px) {
  /* Fix main frame width for very small screens */
  .top .frame {
    width: 100vw ;
    max-width: 100vw ;
  }
  
  /* Reduce max-width for very small screens */
  .top .li-every-other-day,
  .top .img-reason-2,
  .top .container-3,
  .top .img-3,
  .top .list-bottom-3,
  .top .list-bottom-4,
  .top .div-12,
  .top .list-diagnosis,
  .top .list-milight,
  .top .frame-8,
  .top .frame-9,
  .top .frame-10,
  .top .frame-11,
  .top .list-flow {
    max-width: calc(100vw - 40px) ;
    width: 100% ;
  }
  
  /* Reduce horizontal padding for very small screens */
  .top .li-2,
  .top .li-3,
  .top .container-3,
  .top .list-2,
  .top .container-4,
  .top .container-5,
  .top .list-4 {
    padding-left: 12px ;
    padding-right: 12px ;
  }
  
  /* Header padding adjustment */
  .top .header {
    padding-left: 12px ;
    padding-right: 12px ;
  }
}

/* ==============================================
   MOBILE-ONLY STYLES (max-width: 767px)
   ============================================== */

@media (max-width: 768px) {
  /* Mobile base adjustments */
  html, body {
    overflow-x: hidden;
    max-width: 100vw;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
  }
  
  /* Sticky header for mobile */
  .top .header {
    position: fixed ;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;  /* Lower z-index since menu button is outside */
    background-color: #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
  }
  
  /* Hide header on scroll down */
  .top .header.header-hidden {
    transform: translateY(-100%);
  }
  
  /* Mobile menu button - independent from header */
  .mobile-menu-button {
    position: fixed;
    top: 30px;
    right: 16px;
    z-index: 9999999;  /* Highest z-index */
    display: block;
    transition: transform 0.3s ease;
  }
  
  /* Hide menu button on scroll down */
  .mobile-menu-button.menu-button-hidden {
    transform: translateY(-100px);
  }
  
  /* Hide mobile menu button on PC */
  
  /* Add top padding to body content to compensate for fixed header */
  .top .frame {
    padding-top: 80px ;
  }
  
  
  /* Fix wide elements for mobile */
  .top .frame-wrapper,
  .top .frame-3,
  .top .h-worries,
  .top .text-wrapper-75 {
    width: 100% ;
    max-width: 100% ;
  }
  .top .h-worries{
    text-align: center;
  }
  
  .top .img-reason-3 {
    width: 100% ;
    max-width: 100% ;
    margin-right: 0 ;
  }
  
  .top .text-wrapper-68 {
    width: 100% ;
    max-width: 100% ;
  }
  
  /* Mobile menu styles */
  .pc-menu.mobile-menu-open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    right: 0;
    width: 85%;
    max-width: 320px;
    height: 100%;
    background-color: white;
    box-shadow: -5px 0 15px rgba(0, 0, 0, 0.1);
    z-index: 999999;  /* Very high z-index for menu panel */
    padding: 80px 24px 40px;
    overflow-y: auto;
    animation: slideInFromRight 0.3s ease;
  }
  
  @keyframes slideInFromRight {
    from {
      transform: translateX(100%);
    }
    to {
      transform: translateX(0);
    }
  }
  
  .pc-menu.mobile-menu-open .menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  
  .pc-menu.mobile-menu-open .menu-list li {
    margin: 0;
  }
  
  .pc-menu.mobile-menu-open .menu-list a {
    display: flex;
    align-items: flex-start;
    color: var(--color-dark);
    text-decoration: none;
    font-size: 1.125rem;
    font-weight: var(--font-weight-semibold);
    font-family: var(--font-japanese);
    letter-spacing: 0.4px;
    line-height: 1.6rem;
    padding: 5px 0;
    gap: 8px;
    transition: color 0.2s;
  }
  
  .pc-menu.mobile-menu-open .menu-list a::before {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('../img/menu-icon.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    flex-shrink: 0;
    margin-top: 4px;
  }
  
  .pc-menu.mobile-menu-open .menu-list a:hover {
    color: var(--color-primary);
  }

  .top .footer{
    height: 450px;
  }
  
  /* Menu button animation */
  .menu.menu-active .rectangle:first-child {
    transform: rotate(40deg) translate(2px, 2px);
  }
  
  .menu.menu-active .rectangle:last-child {
    transform: rotate(-40deg) translate(6px, -6px);
  }
  
  /* Dark overlay behind menu */
  body.menu-open::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 999998;  /* Just below menu */
    animation: fadeIn 0.3s ease;
  }
  
  @keyframes fadeIn {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }
  
  /* Prevent body scroll when menu is open */
  body.menu-open {
    overflow: hidden;
  }

  /* Mobile fixed bottom button - ONLY for mobile */
  .mobile-fixed-button-container {
    position: fixed ;
    bottom: 0 ;
    left: 0 ;
    right: 0 ;
    z-index: 9000 ;  /* Below menu (100000) and overlay (99998) */
    background: rgba(255, 255, 255, 0.95) ;
    box-shadow: 0 -2px 10px rgba(0,0,0,0.2) ;
    padding: 16px ;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
  }
  
  /* When show class is added - for mobile only */
  .mobile-fixed-button-container.show {
    opacity: 1 ;
    pointer-events: auto ;
  }
  
  /* Button width variations - must be inside media query for mobile */
  .mobile-fixed-button-container.show.btn-width-640 .mobile-fixed-btn {
    width: 98% ;
    max-width: 340px ;
  }
  
  .mobile-fixed-btn {
    justify-content: flex-end;
    gap: 16px;
    padding: 21px 20px 21px 0px;
    width: 350px;
    max-width: 350px;
    margin: 0 auto;
    flex: 0 0 auto;
    box-shadow: 8px 8px 20px #e71d0a4c;
    background: linear-gradient(
      180deg,
      rgba(255, 44, 25, 1) 0%,
      rgba(220, 21, 3, 1) 100%
    );
    display: flex;
    align-items: center;
    position: relative;
    border-radius: 100px;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  
  .mobile-btn-text {
    position: relative;
    width: fit-content;
    margin-top: -2.00px;
    font-family: "BIZ UDPGothic", Helvetica;
    font-weight: 700;
    color: #ffffff;
    font-size: 1.25rem;
    letter-spacing: 0;
    line-height: 20px;
  }
  
  .mobile-btn-badge {
    position: absolute;
    width: 70px;
    height: 67px;
    top: -4px;
    left: -6px;
  }
  
  .mobile-btn-badge .mobile-badge-text {
    position: absolute;
    width: 43px;
    top: 23px;
    left: 16px;
    font-family: "BIZ UDPGothic", Helvetica;
    font-weight: 700;
    color: #e71d0a;
    font-size: 1.25rem;
    letter-spacing: 0;
    line-height: 20px;
  }
  
  .mobile-btn-badge .mobile-badge-overlap {
    position: relative;
    width: 100%;
    height: 100%;
    background-image: url(../img/vector-1.svg);
    background-size: 100% 100%;
  }
  
  .mobile-btn-arrow {
    position: relative;
    width: 15px;
    height: 12px;
    background-image: url(../img/arrow.svg);
    background-size: 100% 100%;
    transition: transform 0.3s ease;
  }
  
  /* List bottom and div-12 width 100% on mobile */
  .top .list-bottom,
  .top .list-bottom-2,
  .top .list-bottom-3,
  .top .list-bottom-4,
  .top .div-12 {
    width: 100% ;
    max-width: 100% ;
  }

  /* Hide page top button on mobile */
  .page-top-btn {
    display: none;
  }

  /* Mobile fixed button - removed duplicate */
  
  /* Make btn-entry-header smaller on mobile */
  .top .btn-entry-header {
    padding: 6px 18px;
    gap: 8px;
    font-size: 0.75rem;
  }
  
  /* Set text-wrapper-3 font-size on mobile */
  .top .text-wrapper-3 {
    font-size: 1rem;
    line-height: 32px;
  }

  
  /* Set element class line-height on mobile */
  .top .element {
    line-height: 18px;
  }
  
  /* Make logo and text horizontal on mobile */
  .header-logo {
    display: flex;
    align-items: left;
    gap: 10px;
  }
  
  .header-logo .logo {
    flex-shrink: 0;
    width: 120px;
    height: auto;
  }
  
  .header-logo .element {
    margin: 0;
    font-size: 0.75rem;
  }
  
  /* Mobile content width and spacing */
  .contents-wrapper {
    max-width: 100%;
    margin-top: 70px;
  }
  
  /* Mobile text scaling - minimal adjustments */
  .top .text-wrapper-4,.top .text-wrapper-44 {
    font-size: 1rem;
  }
  
  /* Ensure images scale properly */
  img {
    max-width: 100%;
    height: auto;
  }
}

/* ==============================================
   TABLET+ STYLES (min-width: 768px)
   ============================================== */

@media (min-width: 769px) {
  /* PC anchor link offset to prevent content being cut off by fixed header */
  html {
    scroll-padding-top: 80px;
  }
  
  /* Additional specific targeting for result sections */
  #result-a,
  #result-b,
  #result-c {
    scroll-margin-top: 0px;
  }
  
  body {
    background-color: var(--color-light-gray);
    position: relative;
  }
  
  /* Remove image gaps on larger screens */
  img {
    display: block;
    margin: 0px;
    padding: 00px;
    vertical-align: top;
  }
  
  .mv,
  .contents-wrapper {
    line-height: 0;
  }
  
  .mv img,
  .contents-wrapper img {
    margin: 0 ;
    padding: 0 ;
  }
  
  .top .mv {
    width: 100%;
    height: auto;
  }
  
  /* Responsive iframe styling */
  .youtube {
    position: relative;
    width: 100%;
    display: flex;
    flex-direction: column;
  }

  
  .youtube .text-wrapper-40 {
    position: static ;
    line-height: 1.4;
    font-size: 0.875rem;
    color: var(--color-dark);
    text-align: left;
  }
  
  /* Responsive Google Maps iframe */
  .map {
    position: relative;
    width: 100% ;
    padding-bottom: 62.86%; /* 350:220 aspect ratio */
    overflow: hidden;
  }
  
  .map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% ;
    height: 100% ;
  }
  
  /* Responsive content wrapper */
  .contents-wrapper {
    width: 100%;
    box-sizing: border-box;
    background: #fff;
  }

  /* Hide mobile elements on PC */
  .mobile-fixed-button-container,
  .mobile-menu-button {
    display: none ;
    opacity: 0 ;
  }

  body::after {
    content: '';
    position: fixed;
    bottom: 10px;
    left: 0;
    width: 200%;
    height: 68px;
    background-image: url('../img/slide-text-container.svg');
    background-size: auto 100%;
    background-position: 0 bottom;
    background-repeat: repeat-x;
    z-index: -1;
    animation: slideRightToLeft 20s linear infinite;
  }
  
  @keyframes slideRightToLeft {
    0% {
      transform: translateX(0);
    }
    100% {
      transform: translateX(-50%);
    }
  }
  
  .top {
    max-width: 1440px;
    width: 100%;
  }
  
  /* Hide mobile header on PC */
  .top .header {
    display: none ;
  }
  
  /* Show and position PC Logo */
  .pc-logo {
    display: flex;
    text-align: center;
    flex-direction: column;
    align-items: flex-start;
    position: fixed;
    top: 50%;
    transform: translateY(-50%);
    left: max(40px, calc(50% - min(720px, 50%)));
    z-index: 1000;
    text-decoration: none;
    color: inherit;
    transition: opacity 0.2s;
  }
  
  .pc-logo:hover {
    opacity: 0.8;
  }

  .top .pc-logo .logo{
    width: 20vw;
    height: auto;
    margin-bottom: 16px;
  }

   .top .element{
    font-size: 2vw;
   }

   .top .element span{
    line-height: 1.4;
   }

   .top .pc-logo .element span.text-wrapper-3{
    font-size: 1.4vw;
    color: #e71d0a;
  }
  
  /* Show and position PC Menu */
  .pc-menu {
    display: flex;
    flex-direction: column;
    position: fixed;
    width: 23vw;
    max-width: 400px;
    top: 50%;
    transform: translateY(-50%);
    right: max(30px, calc(50% - min(720px, 50%)));
    z-index: 1000;
    background: #fff;
    border-radius: 20px;
    padding: 28px;
  }
  
  /* Show and position PC ENTRY Button */
  .pc-entry-btn {
    display: block;
    position: fixed;
    top: 20px;
    right: max(20px, calc(50% - min(720px, 50%)));
    z-index: 1000;
    transition: all 0.3s ease;
    text-decoration: none;
  }
  
  .pc-entry-btn:hover {
    transform: translateY(-2px);
    filter: brightness(1.1);
  }
  
  .menu-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  
  .menu-list li {
    margin: 0;
  }
  
  .menu-list a {
    display: flex;
    align-items: flex-start;
    color: var(--color-dark);
    text-decoration: none;
    font-size: 1.125rem;
    font-weight: var(--font-weight-semibold);
    font-family: var(--font-japanese);
    letter-spacing: 0.4px;
    line-height: 1.6rem;
    padding: 5px 0;
    gap: 8px;
    transition: color 0.2s;
  }
  
  .menu-list a::before {
    content: '';
    width: 16px;
    height: 16px;
    background-image: url('../img/menu-icon.svg');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    flex-shrink: 0;
    margin-top: 4px;
  }
  
  .menu-list a:hover {
    color: var(--color-primary);
  }

  /* Responsive menu width adjustment */
  .pc-menu {
    width: calc(25vw - 20px);
    max-width: 320px;
  }
}

/* ==============================================
   TABLET SPECIFIC (769px - 1200px)
   ============================================== */

@media (min-width: 769px) and (max-width: 1200px) {
  .contents-wrapper {
    width: 42%;
    margin: 0 auto;
  }
  
  .pc-menu {
    width: calc(28vw - 20px);
    max-width: 280px;
    right: 20px;
  }

  .menu-list{
    gap: 8px;
  }

  .top .text-wrapper-5{
    font-size: 1.85vw;
  }
}

/* ==============================================
   SMALLER TABLET ADJUSTMENTS (max-width: 1024px)
   ============================================== */

@media (max-width: 1024px) {
  .pc-menu {
    width: calc(30vw - 20px);
    max-width: 250px;
  }
}

/* ==============================================
   LARGER DESKTOP ADJUSTMENTS (max-width: 1440px)
   ============================================== */

@media (max-width: 1440px) {
  .pc-menu {
    width: calc(25vw - 20px);
    max-width: 320px;
  }
}

/* ==============================================
   DESKTOP STYLES (min-width: 1201px)
   ============================================== */

@media (min-width: 1201px) {
  .contents-wrapper {
    width: 540px;
    margin: 0 auto;
  }
}

@media (min-width: 1440px) {
  .top .text-wrapper-4,.section-reason .text-wrapper-44, .section-flow .text-wrapper-44 {
    font-size: 20px;
  }
}