@charset "UTF-8";
/* 2. リセット & ベーススタイル */
/* =====================================
   Base styles
===================================== */
@import url(normalize.min.css);
/* ===== 基本リセット ===== */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0; }

html {
  margin: 0;
  padding: 0;
  height: 100%;
  overscroll-behavior: none;
  font-size: 100%;
  /* 16px基準 */
  -webkit-text-size-adjust: 100%;
  /* モバイルブラウザでの文字サイズ調整防止 */ }

body {
  height: 100%;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, sans-serif;
  line-height: 1.6;
  color: #444;
  background-color: #fff;
  /*padding: 1rem;*/ }

/* ===== 画像のレスポンシブ対応 ===== */
img {
  max-width: 100%;
  height: auto;
  display: block; }

/* ===== 見出し ===== */
h1, h2, h3, h4, h5, h6 {
  font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1rem;
  color: #222; }

h1 {
  font-size: 2rem;
  line-height: 1.3;
  margin-bottom: 1rem; }

h2 {
  font-size: 1.75rem;
  line-height: 1.3;
  margin-bottom: 0.875rem; }

h3 {
  font-size: 1.5rem;
  line-height: 1.3;
  margin-bottom: 0.75rem; }

p {
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1rem;
  letter-spacing: 0.01em; }

/* ===== タイポグラフィ調整 ===== */
p {
  text-align: justify;
  text-justify: inter-ideograph; }

ul, ol {
  list-style: none; }

/* 共通スタイル */
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
  width: 100%;
  padding: 10px 12px;
  font-size: 16px;
  border: 1px solid #ccc;
  background: #fafafa;
  border-radius: 4px;
  transition: border-color 0.25s, box-shadow 0.25s, background 0.25s;
  box-sizing: border-box; }

/* フォーカス時（クリック or タップ時） */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus {
  border-color: #4a90e2;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.2);
  outline: none; }

/* textarea を見やすく */
textarea {
  min-height: 160px;
  resize: vertical;
  /* 横方向の伸縮は禁止、縦だけ */ }

/* ===== リンクのスタイル ===== */
a {
  color: #007bff;
  text-decoration: none; }

a[target="_blank"]:after {
  font-family: "Font Awesome 6 Free";
  content: "\f08e";
  font-weight: 900;
  margin: 0 0.25rem; }

/*
スマホ
 */
/* 3. ユーティリティクラス */
/* =====================================
   utils
===================================== */
.only-mobile {
  display: block; }

.only-desktop {
  display: none; }

.br-sp {
  display: inline; }

.br-pc {
  display: none; }

/*
------------------------------
*/
.u-title-lg {
  font-size: clamp(1.5rem, 4vw, 2rem);
  line-height: 1.3; }

.u-title-md {
  font-size: clamp(1.25rem, 3vw, 1.5rem);
  line-height: 1.3; }

.u-title-sm {
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  line-height: 1.3; }

.u-text-nowrap {
  white-space: nowrap; }

.u-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap; }

.u-line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden; }

.u-textblock {
  margin-bottom: 4rem; }
  .u-textblock:last-child {
    margin-bottom: 0; }

.container {
  width: 100%;
  padding-left: 1.5rem;
  padding-right: 1.5rem; }
  .container:last-child {
    border-bottom: none; }
  .container--top {
    padding-top: 1rem;
    padding-bottom: 5rem;
    border-bottom: 1px solid #222; }

.u-full-width {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw; }

.u-m-xs {
  margin: 0.75rem; }

.u-m-sm {
  margin: 0.875rem; }

.u-m-md {
  margin: 1rem; }

.u-m-lg {
  margin: 1.25rem; }

.u-m-xl {
  margin: 1.5rem; }

.u-mt-xs {
  margin-top: 0.75rem; }

.u-mt-sm {
  margin-top: 0.875rem; }

.u-mt-md {
  margin-top: 1rem; }

.u-mt-lg {
  margin-top: 1.25rem; }

.u-mt-xl {
  margin-top: 1.5rem; }

.u-mt-2xl {
  margin-top: 2rem; }

.u-mt-3xl {
  margin-top: 3rem; }

.u-mt-4xl {
  margin-top: 4rem; }

.u-mb-xs {
  margin-bottom: 0.8rem; }

.u-mb-sm {
  margin-bottom: 0.9rem; }

.u-mb-md {
  margin-bottom: 1.05rem; }

.u-mb-lg {
  margin-bottom: 1.3rem; }

.u-mb-xl {
  margin-bottom: 1.55rem; }

.u-mb-2xl {
  margin-bottom: 2rem; }

.u-mb-3xl {
  margin-bottom: 3rem; }

.u-mb-4xl {
  margin-bottom: 4rem; }

.u-ml-xs {
  margin-left: 0.75rem; }

.u-ml-sm {
  margin-left: 0.875rem; }

.u-ml-md {
  margin-left: 1rem; }

.u-ml-lg {
  margin-left: 1.25rem; }

.u-ml-xl {
  margin-left: 1.5rem; }

.u-mr-xs {
  margin-right: 0.75rem; }

.u-mr-sm {
  margin-right: 0.875rem; }

.u-mr-md {
  margin-right: 1rem; }

.u-mr-lg {
  margin-right: 1.25rem; }

.u-mr-xl {
  margin-right: 1.5rem; }

.u-p-xs {
  padding: 0.75rem; }

.u-p-sm {
  padding: 0.875rem; }

.u-p-md {
  padding: 1rem; }

.u-p-lg {
  padding: 1.25rem; }

.u-p-xl {
  padding: 1.5rem; }

.u-pt-xs {
  padding-top: 0.75rem; }

.u-pt-sm {
  padding-top: 0.875rem; }

.u-pt-md {
  padding-top: 1rem; }

.u-pt-lg {
  padding-top: 1.25rem; }

.u-pt-xl {
  padding-top: 1.5rem; }

.u-pb-xs {
  padding-bottom: 0.8rem; }

.u-pb-sm {
  padding-bottom: 0.9rem; }

.u-pb-md {
  padding-bottom: 1.05rem; }

.u-pb-lg {
  padding-bottom: 1.3rem; }

.u-pb-xl {
  padding-bottom: 1.55rem; }

.u-pl-xs {
  padding-left: 0.75rem; }

.u-pl-sm {
  padding-left: 0.875rem; }

.u-pl-md {
  padding-left: 1rem; }

.u-pl-lg {
  padding-left: 1.25rem; }

.u-pl-xl {
  padding-left: 1.5rem; }

.u-pr-xs {
  padding-right: 0.75rem; }

.u-pr-sm {
  padding-right: 0.875rem; }

.u-pr-md {
  padding-right: 1rem; }

.u-pr-lg {
  padding-right: 1.25rem; }

.u-pr-xl {
  padding-right: 1.5rem; }

.u-flex {
  display: flex; }

.u-flex-row {
  flex-direction: row; }

.u-flex-column {
  flex-direction: column; }

.u-flex-wrap {
  flex-wrap: wrap; }

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

.u-flex-between {
  justify-content: space-between; }

.u-gap-xs {
  gap: 0.75rem; }

.u-gap-sm {
  gap: 0.875rem; }

.u-gap-md {
  gap: 1rem; }

.u-gap-lg {
  gap: 1.25rem; }

.u-gap-xl {
  gap: 1.5rem; }

.u-gap-2xl {
  gap: 2rem; }

.u-gap-3xl {
  gap: 3rem; }

/* 4. レイアウト構造 */
/* =====================================
   Layout
===================================== */
.wrapper {
  display: flex;
  flex-direction: column;
  min-height: 100vh; }

header a:link, header a:visited, header a:hover, header a:focus, header a:active {
  color: #000; }

#site-header {
  display: flex;
  justify-content: space-between; }

.site-logo {
  margin: 1.35rem 0 0 0.9rem;
  max-width: 88px; }

footer {
  margin: 5rem 0 0;
  padding: 2rem 1rem 1rem;
  background-color: #cbe2e3;
  color: #04080b; }

.fotter__menu-list {
  display: flex;
  justify-content: center; }
.fotter__menu-item {
  padding: 4px;
  font-size: 0.875rem; }
  .fotter__menu-item a,
  .fotter__menu-item a:link,
  .fotter__menu-item a:visited,
  .fotter__menu-item a:hover,
  .fotter__menu-item a:focus,
  .fotter__menu-item a:active {
    color: #04080b; }

.copyright {
  margin: 3.5rem 0 0;
  font-size: 0.875rem;
  letter-spacing: 0.018em;
  text-align: center; }

/* 
モバイルファースト：スマホ基本レイアウト
*/
main {
  flex: 1;
  margin: 0; }

.pages main {
  margin-top: 60px; }

/*

セクションの基本スタイル 

*/
/* 5. コンポーネント（ボタン、カード、メニューなど） */
/* =====================================
   Components
===================================== */
/* ヘッダー共通スタイル */
#site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 60px;
  background-color: rgba(255, 255, 255, 0.98);
  box-shadow: 0 2px 3px rgba(0, 0, 0, 0.02);
  z-index: 1000;
  transition: transform 0.3s ease, opacity 0.3s ease; }

/* トップページでは初期状態は非表示 */
body.home #site-header {
  transform: translateY(-100%);
  opacity: 0; }

/* スクロールで表示 */
body.home.scrolled #site-header {
  transform: translateY(0);
  opacity: 1; }

.btn {
  display: block;
  margin: 0 0 0 auto;
  padding: 0.6rem 0.5rem 0.65rem;
  width: 8rem;
  color: #312b0a;
  text-decoration: none;
  text-align: center;
  border: 1px solid #555;
  border-radius: 500px;
  font-family: "Open Sans", sans-serif;
  font-size: 0.875rem;
  letter-spacing: 0.06em; }
  .btn::after {
    display: inline-block;
    vertical-align: middle;
    line-height: 1;
    font-family: "Material Icons";
    content: "\e5e1";
    font-weight: normal;
    font-style: normal;
    font-size: 1rem; }
  .btn--back {
    margin: 0 auto; }
  .btn--mobile-menu {
    margin: 5rem auto;
    background-color: transparent;
    border: 1px solid #fff;
    color: #fff; }
  .btn--submit {
    display: inline-block;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    text-align: center;
    cursor: pointer;
    padding: 0.5rem;
    background: #000066;
    color: #ffffff;
    border: none;
    line-height: 1; }

/*

キービジュアル

*/
.kv {
  width: 100%;
  overflow: hidden;
  position: relative; }
  .kv__inner {
    position: relative; }
  .kv__title-container {
    margin: 3rem 1.5rem 3.5rem; }
  .kv__title {
    margin: 0;
    font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
    font-size: 2rem;
    font-weight: 400;
    letter-spacing: 0.025em; }
  .kv__en-label {
    margin-top: 0.55rem;
    margin-left: 0.25rem;
    font-size: 0.75rem;
    font-family: "Open Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.05em; }
  .kv__overview {
    margin-bottom: 0.8rem;
    margin-left: 0.25rem;
    font-size: 0.75rem;
    font-family: "Open Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.05em; }
  .kv picture, .kv img {
    width: 100%;
    height: auto; }

/*

キービジュアル

*/
.kv-pages-detail {
  width: 100%;
  overflow: hidden;
  position: relative; }
  .kv-pages-detail__inner {
    position: relative; }
  .kv-pages-detail__title-container {
    margin: 3rem 1.5rem 3.5rem; }
  .kv-pages-detail__title {
    margin: 2rem 0 0;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.025em; }
  .kv-pages-detail__en-label {
    font-size: 0.75rem;
    font-family: "Open Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.05em; }
  .kv-pages-detail__overview {
    margin-bottom: 0.8rem;
    margin-left: 0.25rem;
    font-size: 1rem;
    font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: 0.05em; }
  .kv-pages-detail picture, .kv-pages-detail img {
    width: 100%;
    height: auto; }

/*

カード

*/
.card__body {
  margin-top: 1.05rem; }
.card__title {
  margin-bottom: 0.75rem;
  margin-left: 1px;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0.01em; }
.card__footer {
  margin: 0.875rem 0 0; }

.two-dim-list__row {
  display: flex;
  padding: 4px 0;
  border-bottom: 1px solid #777;
  font-size: 0.875rem;
  line-height: 1.6; }

.two-dim-list__term {
  display: block;
  padding: 1.25rem 0.5rem;
  min-width: 6em;
  /* ラベル部分を揃える */
  font-weight: bold;
  letter-spacing: 0.075em; }

.two-dim-list__description {
  display: block;
  padding: 1.25rem;
  flex: 1;
  letter-spacing: 0.075em; }

body.no-scroll {
  overflow: hidden;
  height: 100%; }

/* 開くボタン */
.hamburger-button {
  display: flex;
  /* 中のspanを縦に並べる */
  flex-direction: column;
  /* 縦方向に並べる */
  justify-content: space-around;
  position: fixed;
  top: 9px;
  right: 0.55rem;
  width: 40px;
  height: 41px;
  z-index: 1001;
  background: #fff;
  color: white;
  font-size: 24px;
  padding: 7px 8px 8px;
  border: none;
  cursor: pointer; }
  .hamburger-button span {
    display: block;
    height: 2px;
    /* 線の太さ */
    width: 100%;
    /* 線の長さ */
    background-color: #333;
    border-radius: 2px;
    /* 角を丸くする */ }

/* モバイルメニュー全体 */
.mobile-menu {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  height: 100vh;
  overflow-y: auto;
  background: #1a1f37;
  color: #fff;
  z-index: 1100;
  padding: 8rem 5rem;
  font-size: 1rem; }
  .mobile-menu__title {
    width: 10rem;
    color: #fff;
    font-size: 2rem; }
  .mobile-menu a {
    color: #fff; }
    .mobile-menu a:link, .mobile-menu a:visited, .mobile-menu a:hover, .mobile-menu a:active {
      color: #fff; }
  .mobile-menu ul {
    margin-top: 4.6rem;
    list-style: none;
    padding: 0; }
  .mobile-menu li {
    margin: 1.7rem 0;
    letter-spacing: 0.08rem; }

/* メニューが開いたとき */
.mobile-menu.is-open {
  display: block;
  animation: fadeIn 0.3s ease; }

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-10px); }
  to {
    opacity: 1;
    transform: translateY(0); } }
/* 閉じるボタン */
.close-button--x {
  position: absolute;
  top: 10px;
  right: 10px;
  background: none;
  border: none;
  color: white;
  font-size: 24px;
  cursor: pointer;
  z-index: 1101; }

/* 6. ページごとの上書き（※必要なら） */
/* =====================================
   pages
===================================== */
.home {
  /* --- KV全体 --- */
  /*
  理念の文章
  */
  /*
  事業紹介
  */
  	/*
  	
  	経営理念
  
  	 */
  	/*
  	
  	会社概要
  
  	 */ }
  .home main {
    margin-top: 0; }
  .home .btn {
    margin: 1.55rem 0 0 auto; }
  .home .kv-top {
    position: relative;
    width: 100%;
    height: 100vh;
    /* ビューポートの高さに合わせる */
    overflow: hidden;
    /* 背景画像 */
    /* コンテンツ（ロゴ・タイトル・ボタン） */
    /* ロゴ */
    /* 白い帯（上） */
    /* 白い帯（下） */
    /*&__white-band.bottom {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      height: 40px;
      padding-bottom: env(safe-area-inset-bottom, 20px); 
      background-color: white;
      z-index: 2;
      }*/ }
    .home .kv-top__bg {
      width: 100%;
      height: 100%;
      object-fit: cover;
      /* 縦横比を維持しつつ画面にフィット */
      display: block; }
    .home .kv-top__content {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      /* 完全中央配置 */
      text-align: center;
      z-index: 2;
      width: 100%; }
    .home .kv-top__white-band-top {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 6px;
      background-color: white;
      z-index: 2; }
  .home .intro {
    padding: 3rem;
    background-color: #040911; }
    .home .intro p {
      text-align: justify;
      line-height: 1.9;
      letter-spacing: 0.025em;
      color: #fff; }
  .home .section-title {
    margin-top: 3rem;
    margin-bottom: 4rem;
    margin-left: 2px;
    font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
    font-size: 2rem;
    font-weight: 400;
    letter-spacing: 0.05rem; }
    .home .section-title__en-label {
      display: block;
      margin-top: 0.75rem;
      margin-left: 0.2rem;
      font-family: "Open Sans", sans-serif;
      font-size: 0.75rem;
      font-optical-sizing: auto;
      font-weight: 400;
      font-style: normal;
      letter-spacing: 0.05em; }
    .home .section-title span {
      display: block; }
  .home .business-summary__list {
    display: flex;
    flex-wrap: wrap;
    margin-left: -0.5rem;
    margin-right: -0.5rem; }
  .home .business-summary__item {
    flex: 0 0 50%;
    padding-left: 0.5rem;
    padding-right: 0.5rem; }
  .home .card {
    color: #222; }
    .home .card__media {
      aspect-ratio: 1 / 0.95;
      /* ← ここで比率を決める */
      overflow: hidden; }
      .home .card__media img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
        /* ← これがポイント */ }
    .home .card__body {
      margin: 0;
      padding: 0.75rem 0; }
    .home .card__title {
      font-size: 1rem;
      font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
      font-weight: 700; }
    .home .card__text {
      font-size: 1rem;
      line-height: 1.45; }
  .home .management-philosophy li {
    display: flex; }
  .home .management-philosophy__accent-img-wrapper {
    width: 34%; }
  .home .management-philosophy__text-wrapper {
    width: 65%;
    min-height: 130px;
    padding-left: 0.875rem; }
  .home .management-philosophy__hedding {
    margin-bottom: 4px;
    font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
    font-weight: 700;
    font-size: 1rem; }
  .home .management-philosophy__text p {
    font-size: 0.875rem; }

.greeting-page {
  margin: 0 auto; }
  .greeting-page__kv {
    background: #f5f5f5;
    padding: 4rem 2rem;
    text-align: center; }
  .greeting-page__kv-inner {
    max-width: 800px;
    margin: 0 auto; }
  .greeting-page .greeting__title {
    font-size: 1.25rem;
    font-weight: bold;
    margin: 0; }
  .greeting-page .greeting__body p {
    text-indent: 1em;
    line-height: 1.85;
    margin-bottom: 1.75em; }
  .greeting-page .greeting__signature {
    margin-top: 3rem;
    text-align: right; }
  .greeting-page .greeting--horizontal {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    text-align: left;
    gap: 1.5rem; }
  .greeting-page .greeting__position {
    margin: 0;
    text-align: right; }
  .greeting-page .greeting__name {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
    text-align: right; }

.business-list .card-list {
  margin-top: 4.5rem; }
.business-list .card-list {
  display: flex;
  flex-direction: column;
  gap: 3rem; }
.business-list .card {
  padding-bottom: 3rem;
  border-bottom: 1px solid #eee; }
  .business-list .card:last-child {
    border: none; }

.business-detail-page .business-detail-description__title {
  font-size: 1rem;
  font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
  font-weight: 400; }
.business-detail-page .business-detail-supplement__title {
  font-size: 1rem;
  font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
  font-weight: 400; }
.business-detail-page .business-detail-supplement__item {
  margin-bottom: 0.8rem; }
.business-detail-page .building-list__item {
  display: flex;
  flex-direction: column; }
.business-detail-page .building-list__name, .business-detail-page .building-list__addr {
  display: block; }

.philosophy-page .management-philosophy__intro {
  margin: 2rem 0;
  font-size: 1.25rem; }
.philosophy-page .management-philosophy-list__item {
  padding: 4rem 1.5rem;
  border-top: 1px solid #222; }
.philosophy-page .management-philosophy-list__hedding {
  padding: 0 0.75rem;
  font-size: 1.75rem;
  font-kerning: normal;
  text-align: justify;
  line-height: 1.4;
  letter-spacing: 0.02em; }
.philosophy-page .management-philosophy-list__body {
  display: flex;
  flex-direction: row;
  gap: 0.75rem;
  margin-top: 2rem; }
.philosophy-page .management-philosophy-list__accent-img-wrapper {
  flex: 1.1;
  margin-top: 0.2rem; }
.philosophy-page .management-philosophy-list__text-wrapper {
  flex: 2;
  margin-top: 0.5rem; }
.philosophy-page .management-philosophy-list__text {
  line-height: 1.75;
  letter-spacing: .005em; }

.mailform .two-dim-list__row {
  flex-direction: column;
  padding: 1rem 0.5rem;
  border: none; }
.mailform .two-dim-list__term {
  padding: 0.25rem 0;
  min-width: 12rem; }
.mailform .two-dim-list__description {
  padding: 0.25rem 0; }
.mailform .btn-area {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 1rem 0.5rem; }

/*
PC
 */
/* ===== メディアクエリ：タブレット以上 ===== */
@media screen and (min-width: 768px) {
  /* 2. リセット & ベーススタイル */
  /* =====================================
     Base styles
  ===================================== */
  /* 3. ユーティリティクラス */
  /* =====================================
     utils
  ===================================== */
  .only-mobile {
    display: none; }

  .only-desktop {
    display: block; }

  .container {
    padding-left: 4rem;
    padding-right: 4rem; }

  /* 4. レイアウト構造 */
  /* =====================================
     Layout
  ===================================== */
  .site-logo {
    margin: 1.2rem 0 0 3.45rem;
    max-width: 92px; }

  .site-nav {
    margin: 1.2rem 2rem 0 0;
    font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
    font-weight: 400;
    font-size: 15px;
    letter-spacing: 0.15em; }
    .site-nav ul {
      display: flex;
      gap: 2rem; }

  .fotter__menu-item a,
  .fotter__menu-item a:link,
  .fotter__menu-item a:visited,
  .fotter__menu-item a:hover,
  .fotter__menu-item a:focus,
  .fotter__menu-item a:active {
    color: #04080b; }

  /* 
  モバイルファースト：スマホ基本レイアウト
  */
  /*
  
  セクションの基本スタイル 
  
  */
  /* 5. コンポーネント（ボタン、カード、メニューなど） */
  /* =====================================
     Components
  ===================================== */
  /*
  
  キービジュアル
  
  */
  /*
  
  キービジュアル
  
  */
  /*
  
  カード
  
  */
  /* 開くボタン */
  /* モバイルメニュー全体 */
  /* メニューが開いたとき */
  /* 閉じるボタン */
  /* 6. ページごとの上書き（※必要なら） */
  /* =====================================
     pages
  ===================================== */
  .home {
    /* --- KV全体 --- */
    /*
    理念の文章
    */
    /*
    事業紹介
    */
    /*
    代表あいさつ
    */
    	/*
    	
    	会社概要
    
    	 */ }
    .home .kv-top {
      /* 背景画像 */
      /* コンテンツ（ロゴ・タイトル・ボタン） */
      /* ロゴ */
      /* 白い帯（上） */
      /* 白い帯（下） */
      /*&__white-band.bottom {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 40px;
        padding-bottom: env(safe-area-inset-bottom, 20px); 
        background-color: white;
        z-index: 2;
        }*/ }
      .home .kv-top__white-band-top {
        height: 8px; }
    .home .intro {
      padding: 6rem 6rem 6.25rem; }
      .home .intro p {
        font-family: "YakuHanJP", "Noto Sans JP", "Meiryo", sans-serif;
        font-weight: 400;
        font-size: 1.25rem;
        font-size: 1.5rem;
        line-height: 2.5;
        letter-spacing: 0.2em; }
    .home .section-title {
      margin-left: 0.5rem;
      margin-bottom: 3.9rem;
      font-size: 2.4rem; }
      .home .section-title__en-label {
        font-size: 0.75rem; }
      .home .section-title span {
        display: block; }
    .home .business-summary__list {
      gap: 0; }
    .home .business-summary__item {
      flex: 20%; }
    .home .card__body {
      padding: 1.5rem 0; }
    .home .card__title {
      font-size: 1.1rem;
      font-weight: 400;
      letter-spacing: 0.04em; }
    .home .card__text {
      font-size: 0.875rem;
      line-height: 1.8;
      letter-spacing: 0.075em; }
    .home .management-philosophy ul {
      display: flex;
      gap: 5rem;
      padding: 0 4rem;
      max-width: 1200px; }
    .home .management-philosophy li {
      display: block;
      flex: 1; }
    .home .management-philosophy__accent-img-wrapper {
      padding: 0 2rem;
      width: auto; }
    .home .management-philosophy__text-wrapper {
      width: auto; }
    .home .management-philosophy__hedding {
      margin: 1.25rem 0 0.5rem;
      min-height: 3.5rem;
      font-size: 1.25rem;
      line-height: 1.35;
      letter-spacing: 0.03em; }
    .home .management-philosophy__text p {
      font-size: 0.875rem;
      line-height: 1.85;
      letter-spacing: 0.075em; }
    .home .greeting__inner {
      display: flex;
      gap: 1rem; }
    .home .greeting__title {
      flex: 1; }
    .home .greeting__body {
      margin-top: 5rem;
      margin-right: 2rem;
      width: 38rem; }
    .home .greeting__text {
      font-size: 1.35rem;
      line-height: 2.5;
      letter-spacing: 0.01em; }
    .home .company-profile__inner {
      display: flex;
      gap: 1rem; }
    .home .company-profile__title {
      flex: 1; }
    .home .company-profile__body {
      margin-top: 5rem;
      margin-right: 2rem;
      width: 38rem; }

  .business-list .card-list {
    margin-top: 5.5rem; }
  .business-list .card-list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 0;
    padding-left: 4rem;
    padding-right: 4rem; }
  .business-list .card {
    flex: 0 0 50%;
    padding-left: 2rem;
    padding-right: 2rem;
    border: none; }
    .business-list .card__text {
      min-height: 3.75rem; }

  .business-dedail-haru-page .business-detail-body {
    background-image: url("../images/img_06.jpg");
    padding-left: 30%;
    background-repeat: no-repeat;
    background-position: 18% 0;
    background-size: 10%; }

  .business-detail-works-page .business-detail-body {
    background-image: url("../images/img_03.jpg");
    padding-left: 30%;
    background-repeat: no-repeat;
    background-position: 15% 0;
    background-size: 15%; }

  .business-detail-pcschool-page .business-detail-body {
    background-image: url("../images/img_23.jpg");
    padding-left: 30%;
    background-repeat: no-repeat;
    background-position: 8% 0;
    background-size: 20%; }

  .business-detail-building-management-page .business-detail-body {
    background-image: url("../images/business-building-management_02.jpg");
    padding-left: 30%;
    background-repeat: no-repeat;
    background-position: 10% 0;
    background-size: 18%; }
  .business-detail-building-management-page .business-detail-supplement {
    padding: 1rem;
    background-color: #eee; }
    .business-detail-building-management-page .business-detail-supplement__item {
      margin-bottom: 1rem;
      font-size: 0.875rem; }
  .business-detail-building-management-page .building-list__item {
    display: flex;
    flex-direction: row; }
  .business-detail-building-management-page .building-list__name, .business-detail-building-management-page .building-list__addr {
    display: inline; }

  .mailform .two-dim-list__row {
    flex-direction: row; } }

/*# sourceMappingURL=style.css.map */
