:root {
  --l-content: 100%; }
  @media (min-width: 768px) {
    :root {
      --l-content: calc(768px - 32px); } }
  @media (min-width: 960px) {
    :root {
      --l-content: calc(960px - 32px); } }
  @media (min-width: 1200px) {
    :root {
      --l-content: calc(1212px - 32px); } }
  @media (max-width: 767px) {
    :root {
      --l-content: calc(100% - 32px); } }

section:nth-of-type(even) {
  background-color: transparent; }

h2 {
  font-size: 32px; }

h3 {
  font-size: 28px; }
  .menulist h3 {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 640px;
    height: 55px;
    margin: 0 auto 25px;
    border-radius: 25px;
    font-weight: 500; }
    #mens .menulist h3 {
      background-color: #000;
      color: #fff; }
    #ladies .menulist h3 {
      background-color: #baac95;
      color: #fff; }
    #perm-color .menulist h3 {
      background-color: #aca8a2;
      color: #fff; }
    @media (min-width: 768px) {
      .menulist h3 + p {
        text-align: center; } }

#generally_menu {
  max-width: 1000px;
  margin: 0 auto 60px; }
  @media (min-width: 768px) {
    #generally_menu {
      display: flex;
      justify-content: space-between; } }
  #generally_menu a {
    width: calc(100% / 3 - 70px / 3);
    height: 75px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    background-color: #e2dcd2;
    border-radius: 35px;
    color: black; }
    @media (max-width: 767px) {
      #generally_menu a {
        width: 100%; } }
  #generally_menu p {
    font-size: 30px;
    line-height: 1;
    margin: unset; }
  #generally_menu span {
    font-size: 16px;
    font-weight: 500; }

#intro {
  margin: 0 auto 60px;
  background-color: #baac95; }
  @media (min-width: 768px) {
    #intro {
      padding: 50px 0; } }

.section_title {
  position: relative;
  display: block;
  text-align: center; }
  @media (min-width: 768px) {
    .section_title + p {
      text-align: center; } }
  .section_title:before {
    position: absolute;
    content: '';
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 100%;
    height: 1px;
    background-color: black; }
  .section_title h2 {
    position: relative;
    z-index: 1;
    width: fit-content;
    width: 100%;
    max-width: 380px;
    margin: 0 auto;
    margin: 0 auto;
    background-color: #fff;
    font-weight: 400; }

.menulist {
  margin-top: 85px; }

.ncMenu {
  gap: 2em 24px;
  margin-bottom: calc(8px * 4); }
  .ncMenu_menu {
    margin-bottom: 0; }
