@charset "UTF-8";

/* =========================================================
   owners.css
   オーナーページ専用
========================================================= */


/* =========================================================
   0. 右側本文エリアの幅制限解除
========================================================= */

body.page-id-9374 .page-standard,
body.page-id-9374 .page-standard__inner,
body.page-id-9374 .page-standard__article,
body.page-id-9374 .page-standard__content,
body.page-id-9374 .right-layout-content,
body.page-id-9374 .entry-content{
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  box-sizing: border-box !important;
}

body.page-id-9374 .entry-content{
  margin: 0 !important;
  padding: 0 !important;
}


/* =========================================================
   1. 全体
========================================================= */

.owners-content,
.owners-content *{
  box-sizing: border-box;
}

.owners-content{
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  background: #fff;
  color: #2a241f;
  font-family: "Noto Serif JP", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  line-height: 1.9;
  overflow: hidden;
}

.owners-content a{
  color: inherit;
  text-decoration: none;
}

.owners-content img{
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

.owners-content button{
  font-family: inherit;
}

.owners-content h1,
.owners-content h2,
.owners-content h3,
.owners-content h4{
  background: none !important;
  border: 0 !important;
  position: static !important;
}


/* =========================================================
   2. 共通
========================================================= */

.owners-section{
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 88px 0;
}

.owners-section__inner{
  width: min(86%, 1180px);
  max-width: 1180px;
  margin: 0 auto;
  padding: 0;
}


/* =========================================================
   3. ヒーロー
========================================================= */

.owners-hero{
  width: 100%;
  max-width: none;
  min-height: 360px;
  margin: 0;
  padding: 0;
  background:
    linear-gradient(rgba(20, 17, 15, 0.58), rgba(20, 17, 15, 0.58)),
    url("/wp-content/uploads/2026/06/38241_01_02-4.jpg") center center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
}

.owners-hero__inner{
  width: min(86%, 980px);
  max-width: 980px;
  margin: 0 auto;
  padding: 76px 20px;
}

.owners-hero__en{
  margin: 0 0 22px;
  color: #d6b21f;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.42em;
  line-height: 1;
}

.owners-hero__title{
  margin: 0 0 24px;
  padding: 0;
  color: #fff !important;
  font-size: clamp(36px, 4.3vw, 58px);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: 0.18em;
  text-align: center;
}

.owners-hero__lead{
  margin: 0;
  color: #fff;
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.08em;
}


/* =========================================================
   4. 見出し
========================================================= */

.owners-heading,
.owners-maint-heading{
  width: 100%;
  margin: 0 0 52px;
  padding: 0;
  text-align: left;
}

.owners-heading__en{
  margin: 0 0 12px;
  color: #c4a018;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.26em;
}

.owners-heading__title,
.owners-maint-heading__title{
  display: inline-block;
  margin: 0;
  padding: 0 0 13px;
  border-bottom: 2px solid #d5b322 !important;
  color: #111;
  font-size: clamp(28px, 2.8vw, 40px);
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: 0.08em;
  text-align: left;
}

.owners-heading__text,
.owners-maint-heading__text{
  max-width: 900px;
  margin: 28px 0 0;
  color: #555;
  font-size: 15px;
  line-height: 2.1;
  letter-spacing: 0.04em;
}

.owners-maint-heading__line{
  display: flex;
  align-items: center;
  gap: 28px;
  margin: 0 0 28px;
}

.owners-maint-heading__en{
  margin: 0;
  color: #aaa;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.22em;
  line-height: 1;
}


/* =========================================================
   5. 緊急・メンテナンス連絡先
========================================================= */

.owners-contact-section{
  background: #fff;
  padding-top: 90px;
  padding-bottom: 95px;
}

.owners-contact-frame{
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  border: 1px solid #e6e1d9;
  background: #fff;
}

.owners-contact-left,
.owners-contact-right,
.owners-contact-bottom{
  min-width: 0;
  padding: 54px 52px;
}

.owners-contact-left{
  border-right: 1px solid #e6e1d9;
}

.owners-contact-right{
  background: #fff;
}

.owners-contact-bottom{
  grid-column: 1 / 2;
  width: 100%;
  border-top: 1px solid #e6e1d9;
  background: #fff;
}

.owners-contact-frame::after{
  content: "";
  display: block;
  grid-column: 2 / 3;
  grid-row: 2 / 3;
  background: #e7e4df;
  border-top: 1px solid #e6e1d9;
}

.owners-contact-title{
  display: flex !important;
  align-items: flex-start !important;
  gap: 14px !important;
  margin: 0 0 22px !important;
  padding: 0 !important;
  color: #111 !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
  letter-spacing: 0.05em !important;
}

.owners-contact-title__icon{
  flex: 0 0 30px !important;
  width: 30px !important;
  height: 30px !important;
  margin-top: 0 !important;
  background-color: #fff !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 17px 17px !important;
  border: 1px solid #d5b322 !important;
  border-radius: 50% !important;
}

.owners-contact-title__icon--home{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d5b322' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 11L12 4l9 7'/%3E%3Cpath d='M5 10v10h14V10'/%3E%3Cpath d='M9 20v-6h6v6'/%3E%3C/svg%3E") !important;
}

.owners-contact-title__icon--gear{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d5b322' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3Cpath d='M19.4 15a1.7 1.7 0 0 0 .3 1.9l.1.1-2.8 2.8-.1-.1a1.7 1.7 0 0 0-1.9-.3 1.7 1.7 0 0 0-1 1.6V21h-4v-.1a1.7 1.7 0 0 0-1-1.6 1.7 1.7 0 0 0-1.9.3l-.1.1-2.8-2.8.1-.1a1.7 1.7 0 0 0 .3-1.9 1.7 1.7 0 0 0-1.6-1H3v-4h.1a1.7 1.7 0 0 0 1.6-1 1.7 1.7 0 0 0-.3-1.9l-.1-.1L7.1 4l.1.1a1.7 1.7 0 0 0 1.9.3 1.7 1.7 0 0 0 1-1.6V3h4v.1a1.7 1.7 0 0 0 1 1.6 1.7 1.7 0 0 0 1.9-.3l.1-.1 2.8 2.8-.1.1a1.7 1.7 0 0 0-.3 1.9 1.7 1.7 0 0 0 1.6 1h.1v4h-.1a1.7 1.7 0 0 0-1.6 1z'/%3E%3C/svg%3E") !important;
}

.owners-contact-title__icon--tel{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d5b322' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2A19.8 19.8 0 0 1 3.1 5.18 2 2 0 0 1 5.1 3h3a2 2 0 0 1 2 1.72c.12.9.33 1.77.62 2.6a2 2 0 0 1-.45 2.11L9 10.7a16 16 0 0 0 4.3 4.3l1.27-1.27a2 2 0 0 1 2.11-.45c.83.29 1.7.5 2.6.62A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E") !important;
}

.owners-contact-text{
  min-height: 118px;
  margin: 0 0 36px;
  color: #555;
  font-size: 13px;
  line-height: 2.05;
  letter-spacing: 0.04em;
}


/* =========================================================
   6. 電話番号カード
========================================================= */

.owners-card-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px 28px;
  align-items: stretch;
}

.owners-card-grid--left{
  margin-top: 0;
}

.owners-card-grid--bottom{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.owners-card{
  min-width: 0;
  min-height: 128px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin: 0;
  padding: 0;
}

.owners-card h4{
  min-height: 42px;
  margin: 0 0 8px;
  color: #111;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.04em;
}

.owners-card p{
  min-height: 48px;
  margin: 0 0 14px;
  color: #888;
  font-size: 11px;
  line-height: 1.75;
  letter-spacing: 0.03em;
}

.owners-card a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 190px;
  height: 44px;
  min-height: 44px;
  margin-top: auto;
  padding: 0 16px;
  background: #111;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-align: center;
}

.owners-card a::before{
  content: "☎";
  margin-right: 8px;
  color: #fff;
  font-size: 13px;
}


/* =========================================================
   7. メンテナンス情報
========================================================= */

.owners-maint-section{
  width: 100%;
  max-width: none;
  margin: 0;
  background: #f8f7f4;
  padding-top: 95px;
  padding-bottom: 95px;
}

.owners-maint-layout{
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  gap: 54px;
  align-items: start;
}

.owners-maint-tabs{
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: 5px;
}

.owners-maint-tab{
  width: 100%;
  height: 64px;
  padding: 0 28px;
  border: 0;
  border-left: 3px solid transparent;
  background: transparent;
  color: #999;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.05em;
  text-align: left;
  cursor: pointer;
  transition: color .2s ease, background .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.owners-maint-tab:hover{
  color: #e49d93;
}

.owners-maint-tab.is-current{
  border-left-color: #d5b322;
  background: #fff;
  color: #e49d93;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.06);
}

.owners-maint-main{
  min-width: 0;
}

.owners-maint-panel{
  display: none;
}

.owners-maint-panel.is-current{
  display: block;
}

.owners-maint-subtitle{
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 28px;
  padding: 0;
  color: #111;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
}

.owners-maint-subtitle__icon{
  flex: 0 0 22px;
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #d5b322;
  background: #fff;
  border: 1px solid #d5b322;
  border-radius: 50%;
  font-size: 11px;
  line-height: 1;
}

.owners-maint-video-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
}

.owners-maint-video-card{
  background: #fff;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.05);
}

.owners-maint-video{
  position: relative !important;
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #ddd;
  overflow: hidden;
}

.owners-maint-video iframe{
  position: absolute !important;
  inset: 0 !important;
  display: block;
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
}

.owners-maint-video-card p{
  margin: 0;
  padding: 17px 20px 20px;
  color: #111;
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0.03em;
}

.owners-maint-maker{
  margin-top: 54px;
}

.owners-maint-maker--top{
  margin-top: 0;
}

.owners-maint-maker-buttons{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 240px));
  gap: 16px;
}

.owners-maint-maker-button{
  position: relative;
  display: flex;
  align-items: center;
  min-height: 56px;
  padding: 0 46px 0 22px;
  border: 1px solid #ded8cd;
  background: #fff;
  color: #333;
  font-size: 13px;
  letter-spacing: 0.04em;
}

.owners-maint-maker-button::after{
  content: "›";
  position: absolute;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  color: #d5b322;
  font-size: 22px;
  line-height: 1;
}


/* =========================================================
   8. 定期点検ご予約フォーム
========================================================= */

.owners-reserve-section{
  background: #fff;
  padding-top: 95px;
  padding-bottom: 95px;
}

.owners-reserve-heading{
  margin-bottom: 45px;
}

.owners-reserve-box{
  position: relative;
  width: 100%;
  min-height: 270px;
  padding: 72px 40px;
  color: #fff;
  text-align: center;
  background:
    linear-gradient(
      rgba(0, 0, 0, 0.48),
      rgba(0, 0, 0, 0.48)
    ),
    url("/wp-content/uploads/2026/06/0054_096A0761_studio9.jpg") center center / cover no-repeat;
  overflow: hidden;
}

.owners-reserve-lead{
  margin: 0 0 14px;
  color: #fff;
  font-size: 18px;
  line-height: 1.8;
  letter-spacing: 0.06em;
}

.owners-reserve-text{
  margin: 0 0 30px;
  color: #fff;
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.04em;
}

.owners-reserve-button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  min-height: 44px;
  padding: 0 28px;
  background: #fff;
  color: #000;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
}


/* =========================================================
   9. 最下部お問い合わせ
========================================================= */

.owners-last-contact-section{
  padding-top: 30px;
  padding-bottom: 95px;
  background: #fff;
}

.owners-last-contact-box{
  border: 1px solid #e6e1d9;
  padding: 58px 40px;
  text-align: center;
}

.owners-last-contact-lead{
  margin: 0 0 12px;
  color: #333;
  font-size: 17px;
  line-height: 1.9;
  letter-spacing: 0.05em;
}

.owners-last-contact-text{
  margin: 0 0 30px;
  color: #777;
  font-size: 14px;
  line-height: 1.9;
}

.owners-last-contact-buttons{
  display: flex;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
}

.owners-last-contact-button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 230px;
  min-height: 48px;
  padding: 0 24px;
  border: 1px solid #111;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.owners-last-contact-button--black{
  background: #111 !important;
  color: #fff !important;
}

.owners-last-contact-button--black:hover{
  background: #c4a018 !important;
  color: #fff !important;
  border: 1px solid #c4a018;
}

.owners-last-contact-button--white{
  background: #fff;
  color: #111;
}


/* =========================================================
   10. 下部写真
========================================================= */

.owners-bottom-photo{
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

.owners-bottom-photo img{
  display: block;
  width: 100%;
  height: auto;
}


/* =========================================================
   11. レスポンシブ
========================================================= */

@media screen and (max-width: 1100px){

  .owners-section__inner{
    width: 90%;
  }

  .owners-contact-left,
  .owners-contact-right,
  .owners-contact-bottom{
    padding: 44px 36px;
  }

  .owners-maint-layout{
    grid-template-columns: 220px minmax(0, 1fr);
    gap: 40px;
  }

}

@media screen and (max-width: 900px){

  .owners-section{
    padding: 70px 0;
  }

  .owners-contact-frame{
    grid-template-columns: 1fr;
  }

  .owners-contact-left{
    border-right: 0;
    border-bottom: 1px solid #e6e1d9;
  }

  .owners-contact-bottom{
    grid-column: auto;
    width: 100%;
  }

  .owners-contact-frame::after{
    display: none;
  }

  .owners-contact-text{
    min-height: 0;
  }

  .owners-maint-layout{
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .owners-maint-tabs{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
  }

  .owners-maint-tab{
    height: 48px;
    padding: 0 12px;
    border-left: 0;
    border-bottom: 3px solid transparent;
    background: #fff;
    text-align: center;
    font-size: 13px;
  }

  .owners-maint-tab.is-current{
    border-bottom-color: #d5b322;
  }

}

@media screen and (max-width: 640px){

  .owners-hero{
    min-height: 280px;
  }

  .owners-hero__inner{
    padding: 54px 18px;
  }

  .owners-hero__title{
    font-size: 32px;
  }

  .owners-hero__lead{
    font-size: 13px;
  }

  .owners-heading__title,
  .owners-maint-heading__title{
    font-size: 26px;
  }

  .owners-maint-heading__line{
    display: block;
  }

  .owners-maint-heading__en{
    margin: 12px 0 0;
  }

  .owners-contact-left,
  .owners-contact-right,
  .owners-contact-bottom{
    padding: 36px 24px;
  }

  .owners-card-grid,
  .owners-card-grid--left,
  .owners-card-grid--bottom,
  .owners-maint-video-grid,
  .owners-maint-maker-buttons{
    grid-template-columns: 1fr;
  }

  .owners-card{
    min-height: 0;
  }

  .owners-card h4,
  .owners-card p{
    min-height: 0;
  }

  .owners-card a{
    width: 100%;
  }

  .owners-maint-tabs{
    grid-template-columns: repeat(2, 1fr);
  }

  .owners-reserve-box{
    padding: 52px 24px;
  }

  .owners-last-contact-box{
    padding: 44px 24px;
  }

  .owners-last-contact-button{
    width: 100%;
  }

}


/* メンテナンス情報 見出し下線 */
body.page-id-9374 .owners-content .owners-maint-heading__title{
  display: inline-block !important;
  padding-bottom: 13px !important;
  border-bottom: 0 !important;
  background: linear-gradient(#d5b322, #d5b322) left bottom / 100% 2px no-repeat !important;
}


/* 定期点検ご予約フォーム ボタン文字 */
body.page-id-9374 .owners-content .owners-reserve-button,
body.page-id-9374 .owners-content .owners-reserve-button:link,
body.page-id-9374 .owners-content .owners-reserve-button:visited{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 180px !important;
  min-height: 44px !important;
  padding: 0 28px !important;
  background: #fff !important;
  color: #111 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: 0.06em !important;
  text-align: center !important;
  text-decoration: none !important;
  opacity: 1 !important;
}

body.page-id-9374 .owners-content .owners-reserve-button:hover{
  background: #c4a018 !important;
  color: #fff !important;
}

/* =========================================
   owners メンテナンス背景
========================================= */

.owners-maint-section{
  position: relative;
  overflow: hidden;
  background: #fff;
}

.owners-maint-section::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("/wp-content/uploads/2026/06/0054_096A0761_studio9.jpg");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  opacity: 0.30; /* 画像を白っぽく薄く見せる */
  z-index: 0;
}

.owners-maint-section::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.78); /* 白透過 */
  z-index: 1;
}

.owners-maint-section .owners-section__inner{
  position: relative;
  z-index: 2;
}