/* --------------------------------
  共通スタイル
-------------------------------- */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-padding-top: 100px;
  scroll-behavior: smooth;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #000;
  background: #fff;
  margin: 0;
  padding: 0;
  line-height: 2;
}

fieldset {
  display: none;
}

a {
  color: inherit;
  text-decoration: none;
  transition: 0.3s;
  display: inline-block;
}

a:hover {
  opacity: 0.5;
}

img {
  max-width: 100%;
  height: auto;
  display: inline-block;
}

p {
  text-align: justify;
}

p:not(:last-of-type) {
  margin-bottom: 1em;
}

ul {
  list-style: none;
}

*[data-weight="bold"] {
  font-weight: 700;
}

*[data-weight="black"] {
  font-weight: 900;
}

.Container {
  position: relative;
  overflow: hidden;
}

.En {
  font-family: "Outfit", sans-serif;
}

/* --------------------------------
  Header
-------------------------------- */
.Header-Inner {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1280px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 32px;
  display: flex;
  background: #fff;
  z-index: 99;
}

.Header-Menu {
  gap: 60px;
  margin: 0;
  list-style: none;
  font-size: 20px;
  font-weight: 900;
}

.Header-Logo {
  width: 200px;
  margin: 0;
  line-height: 0;
}

.Header-Fixed.Fixed {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  max-width: 1280px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 32px;
  background: #fff;
}

.Header-Fixed.Fixed .Header-Item {
  font-style: normal;
  transform: none;
}

.Header-Fixed.Fixed .Header-Menu {
  display: flex;
  gap: 60px;
  margin: 0;
}

.Header-Fixed.Fixed .Header-Item:not(:last-child) {
  margin-bottom: 0;
}

/* --------------------------------
  Main
-------------------------------- */

.Page-Title {
  font-size: 70px;
  font-weight: 900;
  display: flex;
  margin: 0;
  line-height: 1;
}

.Page-Subtitle {
  display: block;
  font-size: 20px;
  margin: 0 0 50px;
  line-height: 1;
}

.Main-Inner {
  max-width: 1264px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}

.Page-Wrapper {
  position: relative;
  padding: 240px 24px 320px;
}

.Page-Wrapper::after {
  position: absolute;
  top: 240px;
  left: 0;
  font-size: 160px;
  font-weight: 900;
  color: #e6e6e6;
  z-index: -1;
  white-space: nowrap;
  writing-mode: vertical-rl;
  font-family: "Outfit", sans-serif;
  line-height: 1;
}

.Page-Inner {
  max-width: 592px;
  margin: 0 auto;
}

.Main-Section {
  display: flex;
  justify-content: space-between;
  gap: 32px;
  position: relative;
}

.Main-Section[data-reverse="true"] {
  flex-direction: row-reverse;
}

.Section-Title {
  display: inline-block;
  transform: rotate(-10deg);
  font-style: italic;
  margin-bottom: 40px;
}

.Section-Title-Content {
  margin: 0 0 4px;
  font-size: 72px;
  font-weight: 900;
  line-height: 1;
  position: relative;
}

.Section-Title-Subtitle {
  font-weight: 500;
  font-size: 20px;
}

.Section-Title-Subtitle::before {
  display: flex;
  content: "";
  position: absolute;
  height: 18px;
  z-index: -1;
}

.Section-Title-Subtitle::after {
  display: flex;
  content: "";
  position: absolute;
  height: 34px;
  z-index: -1;
}

.Section-Title-Subtitle[data-color="orange"]::after,
.Section-Title-Subtitle[data-color="orange"]::before {
  background-color: #ff8a24;
}

.Section-Title-Subtitle[data-color="yellow"]::after,
.Section-Title-Subtitle[data-color="yellow"]::before {
  background-color: #fad715;
}

.Section-Title-Subtitle[data-color="turquoise"]::after,
.Section-Title-Subtitle[data-color="turquoise"]::before {
  background-color: #04c1c5;
}

.Section-Content-Title {
  font-size: 32px;
  line-height: 1.5;
  margin-bottom: 32px;
}

@media screen and (max-width: 1000px) {
  .Page-Wrapper::after {
    display: none;
  }
}

/* --------------------------------
  Footer
-------------------------------- */
.Footer {
  background-color: #000;
  color: #fff;
  padding: 80px 24px;
}

/* footer */
.Footer-Inner {
  max-width: 1216px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}

.Footer-Logo {
  max-width: 239px;
}

.Footer-Menu {
  list-style: none;
  margin-bottom: 80px;
  padding: 0;
  display: flex;
  gap: 80px;
}

.Footer-Item>.Footer-Item-link {
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  font-size: 15px;
}

.Footer-Sub li::before {
  content: "- ";
}

/* ───── プライバシーポリシー ───── */
.Footer a[href*="privacy-policy"] {
  margin-top: 20px;
  color: #fff;
  font-size: 14px;
}

/* ───── コピーライト ───── */
.Footer-Copy {
  margin-top: 20px;
  font-size: 12px;
}

.Footer-Copy small {
  color: #fff;
}

.Footer-Sub {
  list-style: none;
  padding: 32px 0 0;
  margin: 0;
}

.Footer-Sub li:not(:last-child) {
  margin-bottom: 16px;
}

.Footer-Sub a {
  color: #fff;
  font-size: 13px;
  text-decoration: none;
  font-weight: 400;
}

.Footer-Bottom {
  display: flex;
  justify-content: space-between;
  max-width: 1216px;
  margin: 0 auto;
  border-top: #fff 1px solid;
}

/* --------------------------------
  レスポンシブSP
-------------------------------- */
@media screen and (max-width: 768px) {
  .Header-Fixed.Fixed {
    left: 0;
    padding: 0;
    transform: none;
    background: none;
  }

  .Header-Nav {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    max-width: 1216px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 4px 32px;
    background: rgba(255, 255, 255, .7);
    z-index: 99;
    box-shadow: 0 -2px 4px rgba(0, 0, 0, .2);
  }

  .Header-Inner {
    bottom: -5px;
    top: auto;
    left: 0;
    padding: 40px 10px;
    width: 100%;
    transform: none;
    justify-content: center;
    position: relative;
  }

  .Header-Inner .Header-Menu {
    gap: 15px;
    justify-content: center;
    padding: 0;
  }

  .Header-Menu .Header-Item:not(:last-child) {
    border-right: 1px solid #666;
    padding-right: 15px;
  }

  .Header-Logo {
    position: fixed;
    top: 24px;
    left: 24px;
    width: 160px;
  }

  .Header-Nav.Fixed {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    max-width: 1216px;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 4px 32px;
    background: rgba(255, 255, 255, .7);
    z-index: 99;
    box-shadow: 0 -2px 4px rgba(0, 0, 0, .2);
    opacity: 1;
  }

  .Header-Fixed.Fixed .Header-Menu {
    gap: 15px;
    justify-content: center;
    padding: 0;
  }

  .Page-Wrapper {
    max-width: 592px;
    margin: 0 auto;
    padding: 75px 24px 100px;
    position: relative;
  }

  .Page-Title {
    font-size: 48px;
    margin-top: 0;
  }

  .Main-Section {
    flex-direction: column-reverse;
    gap: 18px;
  }

  .Main-Section[data-reverse="true"] {
    flex-direction: column-reverse;
  }

  .Section-Title-Content {
    font-size: 52px;
  }

  .Section-Title-Subtitle::after {
    height: 45px;
    width: 250%;
  }

  .Section-Content-Title {
    font-size: 24px;
    margin-bottom: 38px;
  }

  .Footer {
    padding: 48px 24px;
    position: relative;
    z-index: 100;
  }

  .Footer-Inner {
    flex-direction: column;
    gap: 32px;
    max-width: 100%;
  }

  .Footer-Logo {
    text-align: left;
  }

  .Footer-Menu {
    flex-direction: column;
    gap: 24px;
    margin-bottom: 40px;
  }

  .Footer-Item>.Footer-Item-link {
    font-size: 28px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .Footer-Sub {
    display: none;
    padding-top: 16px;
  }

  .Footer-Sub-link {
    font-size: 14px;
  }

  .Footer-Bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    max-width: 100%;
    border: none;
  }

  .Footer-Copy {
    font-size: 11px;
    margin-top: 0;
  }

  /* フッターメニューの開閉 */
  .Footer-Item:nth-child(1)>.Footer-Item-link::after
  /*.Footer-Item:nth-child(2)>.Footer-Item-link::after*/ {
    content: "+";
    font-size: 28px;
    line-height: 1;
  }

  .Footer-Item.open>.Footer-Item-link::after {
    content: "-";
  }
}
