@charset "UTF-8";

/* ==================================================
  街かどモデルハウス 明石台「杜の家」LP
  全セレクター #contents 配下にスコープ
  モバイルファースト → 975 / 1100 / 1536 / 1537
================================================== */

:root {
  /* LP デザイントークン（役割ベース。値は差し替え可能） */
  --lp-brand: #21366e;
  --lp-text: #212121;
  --lp-text-subtle: #444444;
  --lp-surface-soft: #f0f0f0;
  --lp-surface-warm: #f7f4ef;
  --lp-accent: #8f7f2d;
  --lp-accent-line: #f7d7ba;
  --lp-border-muted: #96a5a8;
  --lp-action: #3f6ebe;
  --lp-surface-deep: #717d7d;
  --lp-surface-base: #ffffff;
  --lp-canvas: #ffffff;
}
#contents h1{
    padding: 0;
}
#contents .lp-wrapper {
  box-sizing: border-box;
  max-width: 390px;
  margin: 0 auto;
  position: relative;
  padding-bottom: 5.5em;
  background: var(--lp-surface-base);
  color: var(--lp-text);
}
#contents .pcBlock{display: none}
#contents .spBlock{display: block}

@media (min-width: 975px) {
  #contents .lp-wrapper {
    max-width: 768px;
  }
    #contents .pcBlock{display: block}
    #contents .spBlock{display: none}
}

@media (min-width: 1100px) {
  #contents .lp-wrapper {
    max-width: 976px;
  }
}

@media (min-width: 1536px) {
  #contents .lp-wrapper {
    max-width: 1100px;
  }
}

@media (min-width: 1537px) {
  #contents {
    background: var(--lp-canvas);
  }
}

/* ----- 固定CTA ----- */
#contents .lp-fixed-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: var(--lp-surface-base);
  border-top: 1px solid #ddd;
  padding: 0.625em 1em;
  padding-bottom: calc(0.625em + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.06);
}

#contents .lp-fixed-cta-inner {
  max-width: 390px;
  margin: 0 auto;
}

#contents .lp-fixed-cta-btn {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: var(--lp-action);
  color: var(--lp-surface-base);
  font-size: 0.9rem;
  font-weight: 700;
  text-align: center;
  padding: 1em 1.25em;
  text-decoration: none;
  letter-spacing: 0.02em;
  line-height: 1.4;
  border: none;
}

@media (min-width: 1025px) {
  #contents .lp-fixed-cta-btn {
    font-size: 1rem;
    transition: background-color 0.2s ease, color 0.2s ease;
  }

  #contents .lp-fixed-cta-btn:focus-visible {
    outline: 2px solid var(--lp-action);
    outline-offset: 3px;
  }
}

/* ----- FV（ビューポート幅いっぱい） ----- */
#contents .lp-wrapper #section1 .fv-container {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  background: var(--lp-surface-base);
  border-bottom: 1px solid rgba(247, 215, 186, 0.95);
}

#contents .lp-wrapper .fv-layout {
  display: flex;
  flex-direction: column;
  width: 100%;
}

#contents .lp-wrapper .fv-col--visual {
  position: relative;
  min-height: 15rem;
  overflow: hidden;
}

#contents .lp-wrapper .fv-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

#contents .lp-wrapper .fv-col--visual-wide {
  aspect-ratio: 16 / 10;
}

#contents .lp-wrapper .fv-col--visual-portrait {
  aspect-ratio: 16 / 10;
}

#contents .lp-wrapper .fv-col--copy {
  position: relative;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  justify-content: center;
  background: var(--lp-surface-base);
}

#contents .lp-wrapper .fv-content {
  width: 100%;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  background: var(--lp-surface-base);
}

#contents .lp-wrapper .fv-contentInner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.1em;
  width: 100%;
  padding: 2rem 1.25rem;
}

#contents .lp-wrapper .fv-stack-top,
#contents .lp-wrapper .fv-stack-bottom {
  flex: 0 0 auto;
  box-sizing: border-box;
  width: 100%;
  background: transparent;
  padding: 0;
  text-align: left;
}

@media (min-width: 976px) {
  #contents .lp-wrapper #section1 .fv-container {
    background: var(--lp-surface-base);
  }

  #contents .lp-wrapper .fv-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(380px, 440px) minmax(0, 1fr);
    align-items: stretch;
    min-height: 34rem;
  }

  #contents .lp-wrapper .fv-col--visual {
    min-height: 34rem;
  }

  #contents .lp-wrapper .fv-col--visual-wide,
  #contents .lp-wrapper .fv-col--visual-portrait,
  #contents .lp-wrapper .fv-col--copy {
    min-width: 0;
  }

  #contents .lp-wrapper .fv-col--visual-wide,
  #contents .lp-wrapper .fv-col--visual-portrait {
    aspect-ratio: auto;
  }

  #contents .lp-wrapper .fv-col--copy {
    min-height: 34rem;
    z-index: 1;
    padding: 0;
  }

  #contents .lp-wrapper .fv-content {
    min-height: 100%;
    border-left: 1px solid rgba(247, 215, 186, 0.95);
    border-right: none;
    box-shadow: none;
  }

  #contents .lp-wrapper .fv-contentInner {
    min-height: 100%;
    padding: 3.25rem 2.25rem;
  }
}

#contents .lp-wrapper .fv-property-name {
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: var(--lp-brand);
  margin: 0 0 0.9rem;
  padding-bottom: 0.65em;
  border-bottom: solid 1px rgba(33, 54, 110, 0.2);
}

#contents .lp-wrapper .fv-property-icon {
  width: 1.05em;
  height: 1.05em;
  margin-right: 0.4em;
  vertical-align: -0.13em;
  fill: currentColor;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .fv-property-name {
    font-size: 1rem;
  }
}

#contents .lp-wrapper .fv-headline {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--lp-brand);
  line-height: 1.55;
  margin: 0;
  text-shadow: none;
  letter-spacing: 0.08em;
}

@media (min-width: 975px) {
  #contents .lp-wrapper .fv-headline {
    font-size: 1.8rem;
  }
}



#contents .lp-wrapper .fv-subtext {
  font-size: 1rem;
  line-height: 1.9;
  color: var(--lp-text-subtle);
  margin: 0 0 1.35em;
  text-align: left;
  letter-spacing: 0.05em;
}
#contents .lp-wrapper p.fv-subtext strong {
  font-weight: 700;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .fv-subtext {
    font-size: 1.1rem;
  }
}

#contents .lp-wrapper .fv-cta {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: var(--lp-surface-base);
  color: var(--lp-brand);
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  padding: 1.05em 1.2em;
  text-decoration: none;
  letter-spacing: 0.02em;
  line-height: 1.4;
  margin-bottom: 0;
  border: 1px solid rgba(33, 54, 110, 0.28);
  box-shadow: 0 5px 12px rgba(8, 15, 30, 0.1);
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .fv-cta {
    font-size: 1rem;
  }
}

/* FV コピー内側：ブランドトーン＋ライト面 */
#contents .lp-wrapper .fv-contentInner .fv-property-name {
  color: var(--lp-brand);
}

#contents .lp-wrapper .fv-contentInner .fv-headline {
  color: var(--lp-brand);
  text-shadow: none;
}

#contents .lp-wrapper .fv-contentInner .fv-subtext {
  color: var(--lp-text-subtle);
  position: relative;
  padding: 0;
}

#contents .lp-wrapper .fv-contentInner .fv-subtext::before,
#contents .lp-wrapper .fv-contentInner .fv-subtext::after {
  display: none;
  content: none;
}

#contents .lp-wrapper .fv-contentInner .fv-cta {
  background: linear-gradient(135deg, #f8fafc 0%, #e6edf8 100%);
  color: var(--lp-brand);
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
  max-width: none;
}

#contents .lp-wrapper .fv-contentInner .fv-cta:focus-visible {
  outline: 2px solid var(--lp-surface-base);
  outline-offset: 3px;
}

/* ----- SECTION 2 コンセプト（先頭：幅タブレット・PC時テキスト中央） ----- */
#contents .lp-wrapper .section2-intro {
  position: relative;
  z-index: 0;
  padding: 3.25em 1.25em 2.5em;
  max-width: 768px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

/* 本文幅は max-width のまま、背景だけビューポート全幅 */
#contents .lp-wrapper .section2-intro::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 100vw;
  transform: translateX(-50%);
  background: var(--lp-surface-warm);
  z-index: -1;
}

@media (min-width: 976px) {
  #contents .lp-wrapper .section2-intro {
    text-align: center;
  }
}

#contents .lp-wrapper .concept-lead-h2 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.5;
  color: var(--lp-text);
  margin: 0;
  padding: 0.5em 0 1.5em;
    letter-spacing: 0.05em;
}

/* マーカーは strong のみ（行ボックス下端に固定高の白帯＝クリーム地とも判別しやすい） */
/*#contents p strong,*/
#contents h2 strong,
#contents h3 strong {
  font-weight: inherit;
  display: inline;
  padding: 0.08em 0.08em 0.2em;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  background-image: linear-gradient(var(--lp-accent-line), var(--lp-surface-warm));
  background-size: 100% 0.5em;
  background-position: left 100%;
  background-repeat: no-repeat;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .concept-lead-h2 {
    font-size: 1.5rem;
  }
}

#contents .lp-wrapper .concept-lead-text {
  line-height: 2;
  margin: 0 0 1em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .concept-lead-text {
    line-height: 1.9;
  }
}

#contents .lp-wrapper .terrace-block {
  background: var(--lp-surface-base);
  padding: 3em 1.25em;
}

#contents .lp-wrapper .terrace-h3 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.66;
  color: var(--lp-text);
  margin: 0 0 1.5em;
    padding: 0.5em;
    letter-spacing:0.05em;
    background-color: var(--lp-surface-warm);
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .terrace-h3 {
    font-size: 1.375rem;
    margin-top: 2em;
  }
}

#contents .lp-wrapper .terrace-img {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 0 1em;
  vertical-align: middle;
}
#contents .lp-wrapper .terrace-text {
  margin: 0 0 0.9rem;
}
#contents p {
    font-size: 1.1em;
  line-height: 1.8;
  margin: 0 0 0.5em;
}

@media (min-width: 976px) {
  #contents .lp-wrapper .terrace-media-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5em;
    align-items: center;
    margin: 0 0 1em;
  }

  #contents .lp-wrapper .terrace-media-row .terrace-img,
  #contents .lp-wrapper .terrace-media-row .terrace-text {
    margin: 0;
  }

  #contents .lp-wrapper .terrace-media-row .terrace-text {
    align-self: center;
    justify-self: center;
  }
}

#contents .lp-wrapper .section2-cta-wrap {
  padding: 0 1.25em 3.25em;
  background: var(--lp-surface-base);
}

/* ----- 共通：フル幅セクション ----- */
#contents .lp-wrapper .lp-full-bleed {
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  box-sizing: border-box;
}

/* ----- 共通：セクション内 ----- */
#contents .lp-wrapper .section-inner {
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  padding: 3.5em 1.25em;
  box-sizing: border-box;
}

/* 共通CTA（幅タブレット） */
#contents .lp-wrapper .lp-cta-tablet {
  max-width: 768px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

/* 共通：PC時テキスト中央 */
@media (min-width: 976px) {
  #contents .pcTxtCenter {
    text-align: center;
  }

  /* inline-block なラベルは要素自体も中央寄せ */
  #contents .section-label.pcTxtCenter {
    display: table;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ----- 共通：本文テキスト（font-size / color） ----- */
#contents .lp-wrapper .concept-lead-text,
#contents .lp-wrapper .terrace-text,
#contents .lp-wrapper .section-lead,
#contents .lp-wrapper .spaces-lead-text,
#contents .lp-wrapper .space-card-text,
#contents .lp-wrapper .perf-text {
  font-size: 0.9rem;
  color: var(--lp-text-subtle);
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .concept-lead-text,
  #contents .lp-wrapper .terrace-text,
  #contents .lp-wrapper .section-lead,
  #contents .lp-wrapper .spaces-lead-text,
  #contents .lp-wrapper .space-card-text,
  #contents .lp-wrapper .perf-text {
    font-size: 1rem;
    color: var(--lp-text);
  }
}

/* ----- 共通：ブルーボタン hover ----- */
@media (min-width: 1025px) {
  #contents .lp-fixed-cta-btn:hover,
  #contents .lp-wrapper .fv-contentInner .fv-cta:hover,
  #contents .lp-wrapper .btn-primary:hover {
    background: #3460a8;
    color: #e8f1ff;
  }
}

#contents .lp-wrapper .section-label {
  display: inline-block;
  font-size: 0.6875rem;
  letter-spacing: 0.14em;
  color: var(--lp-accent);
  border: 1px solid var(--lp-border-muted);
  padding: 0.25em 0.65em;
  margin: 0 0 0.9rem;
  text-transform: uppercase;
  font-weight: 700;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .section-label {
    font-size: 0.6875rem;
  }
}

#contents .lp-wrapper .section-heading {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.65;
  margin: 0 0 0.9rem;
  color: var(--lp-text);
    padding: 0.5em;
    background-color: var(--lp-surface-warm);
    letter-spacing: 0.05em;
}
#contents .lp-wrapper .section-heading2 {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.45;
  margin: 0 0 0.9rem;
  color: var(--lp-surface-base);
    letter-spacing: 0.05em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .section-heading,
    #contents .lp-wrapper .section-heading2{
    font-size: 1.5rem;
  }
}

#contents .lp-wrapper .section-lead {
  margin: 0.5em 0;
}
#contents .lp-wrapper .section-lead p{
  line-height: 1.85;
  margin: 0.5em 0 0.5em;
}

/* full-bleed（パディング相殺） */
#contents .lp-wrapper .full-bleed-img {
  display: block;
  max-width: 100%;
  height: auto;
  object-fit: cover;
  box-sizing: border-box;
}



#contents .lp-wrapper .plan-spec-list {
  list-style: none;
  margin: 0.625em 0 0;
  padding: 0;
}

#contents .lp-wrapper .plan-spec-list li {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--lp-text-subtle);
  letter-spacing: 0.02em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .plan-spec-list li {
    color: #565656;
  }
}

/* ----- ボタン ----- */
#contents .lp-wrapper .btn-primary {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: var(--lp-action);
  color: var(--lp-surface-base);
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  padding: 1.125em 1.25em;
  border: none;
  cursor: pointer;
  text-decoration: none;
  line-height: 1.4;
  letter-spacing: 0.05em;
  margin-bottom: 1em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .btn-primary {
    font-size: 1rem;
    transition: background-color 0.2s ease, color 0.2s ease;
  }

  #contents .lp-wrapper .btn-primary:focus-visible {
    outline: 2px solid var(--lp-surface-base);
    outline-offset: 3px;
  }
}

#contents .lp-wrapper .btn-secondary {
  display: block;
  width: 100%;
  box-sizing: border-box;
  background: transparent;
  color: var(--lp-brand);
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  padding: 1em 1.25em;
  border: 2px solid var(--lp-brand);
  cursor: pointer;
  text-decoration: none;
  line-height: 1.4;
  font-family: inherit;
}

/* インラインSVGアイコン（予約/シェア） */
#contents .btn-icon {
  display: inline-block;
  width: 1.1em;
  height: 1.1em;
  margin-right: 0.45em;
  vertical-align: -0.12em;
  fill: currentColor;
  flex-shrink: 0;
  pointer-events: none;
}

#contents .btn-icon-label {
  display: inline;
}

@media (max-width: 975px) {
  #contents .btn-icon-label {
    font-weight: 700;
  }
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .btn-secondary {
    font-size: 1rem;
  }
}

/* ----- SECTION 3 スペース（薄いグレー背景をビューポート全幅） ----- */
#contents .lp-wrapper #section3 {
  background: var(--lp-surface-soft);
}

#contents .lp-wrapper .spaces-divider {
  height: 2px;
  background: var(--lp-border-muted);
  margin: 0 1.25em;
}

#contents .lp-wrapper .spaces-lead {
  background: var(--lp-surface-soft);
  padding: 3em 1.25em 1em;
  max-width: 768px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

@media (min-width: 976px) {
  #contents .lp-wrapper .spaces-lead {
    text-align: center;
  }
}

#contents .lp-wrapper .spaces-h2 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.45;
  color: var(--lp-text);
  margin: 0.5em 0 0.75em;
  letter-spacing: 0.05em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .spaces-h2 {
    font-size: 1.5rem;
  }
}

#contents .lp-wrapper .spaces-lead-strong {
  font-size: 1rem;
  font-weight: 700;
  color: var(--lp-text);
  margin: 0 0 0.75em;
  line-height: 1.5;
    letter-spacing: 0.05em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .spaces-lead-strong {
    font-size: 1.1rem;
  }
}

#contents .lp-wrapper .spaces-lead-text {
  line-height: 1.8;
  margin: 0;
}

#contents .lp-wrapper #section3 .space-slider-box {
  max-width: 1100px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

#contents .lp-wrapper .space-slider-wrap {
  padding: 1.5em 0 0.5em;
  background: transparent;
}

#contents .lp-wrapper .space-slider-wrap .slick-list {
  padding: 0 1.25em;
  box-sizing: border-box;
}

/* section3 スライダー：固定幅スライド（カード寸法は狭い画面時の2枚表示に合わせて維持） */
/* slick は float トラックのため行内で高さが揃わない → 同一行は flex で最大高に合わせる */
#contents .lp-wrapper #section3 .space-slider .slick-track {
  display: flex !important;
  align-items: stretch;
}

#contents .lp-wrapper #section3 .space-slider .slick-track::before,
#contents .lp-wrapper #section3 .space-slider .slick-track::after {
  display: none;
  content: none;
}

@media (max-width: 975px) {
  #contents .lp-wrapper #section3 .space-slider .slick-slide {
    width: calc(100vw - 2.5rem);
    max-width: 24rem;
    padding: 0 0.375em 0.5em;
    box-sizing: border-box;
    float: none;
    height: auto;
    display: flex !important;
    flex-direction: column;
  }
}

@media (min-width: 976px) {
  #contents .lp-wrapper #section3 .space-slider .slick-slide {
    /* 約1000px幅時・lp-wrapper 769px帯で2枚分に近い外寸（356×2＋間 ≒ トラック内幅） */
    width: 356px;
    padding: 0 6px 0.5em;
    box-sizing: border-box;
    float: none;
    height: auto;
    display: flex !important;
    flex-direction: column;
  }
}

#contents .lp-wrapper .space-card {
  background: var(--lp-surface-base);
  margin: 0 0 0.5em;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

/* スライダー内カードは行の最大高まで伸ばし、テキストエリアを下まで埋める */
#contents .lp-wrapper #section3 .space-slider .slick-slide .space-card {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  width: 100%;
  margin-bottom: 0;
}

#contents .lp-wrapper #section3 .space-slider .space-card-img {
  flex-shrink: 0;
}

#contents .lp-wrapper #section3 .space-slider .space-card-body {
  flex: 1 1 auto;
}

#contents .lp-wrapper .space-card-img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  height: auto;
}

#contents .lp-wrapper .space-card-body {
  padding: 1.25em;
}

#contents .lp-wrapper .space-card-room {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--lp-accent);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 0.375em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .space-card-room {
    font-size: 0.75rem;
  }
}

#contents .lp-wrapper .space-card-heading {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.4;
  color: var(--lp-text);
  margin: 0 0 0.625em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .space-card-heading {
    font-size: 1.25rem;
  }
}

#contents .lp-wrapper .space-card-text {
  line-height: 1.8;
  margin: 0;
}

#contents .lp-wrapper .spaces-cta-wrap {
  background: var(--lp-surface-soft);
  padding: 2.5em 1.25em 3.25em;
}

/* slick（#contents 内のみ） */
#contents .lp-wrapper .space-slider-wrap .slick-dots {
  position: relative;
  bottom: auto;
  margin: 0.75em 0 0;
  padding: 0;
}

#contents .lp-wrapper .space-slider-wrap .slick-dots li button:before {
  font-size: 8px;
  color: var(--lp-brand);
  opacity: 0.35;
}

#contents .lp-wrapper .space-slider-wrap .slick-dots li.slick-active button:before {
  opacity: 1;
  color: var(--lp-brand);
}

/* slick.css の矢印は /sumai/ 配下の画像依存のため LP では表示されない → 文字矢印で上書き */
#contents .lp-wrapper .space-slider-wrap .slick-prev,
#contents .lp-wrapper .space-slider-wrap .slick-next {
  width: 2.25rem;
  height: 2.25rem;
  z-index: 2;
  top: 50%;
  bottom: auto;
  margin-top: 0;
  padding: 0;
  border: none;
  background-color: var(--lp-brand);
  background-image: none;
}

#contents .lp-wrapper .space-slider-wrap .slick-prev:hover,
#contents .lp-wrapper .space-slider-wrap .slick-next:hover {
  background-color: #1a2d52;
  background-image: none;
}

#contents .lp-wrapper .space-slider-wrap .slick-prev {
  left: 0.25rem;
  transform: translateY(-50%);
}

#contents .lp-wrapper .space-slider-wrap .slick-next {
  right: 0.25rem;
  transform: translateY(-50%);
}

#contents .lp-wrapper .space-slider-wrap .slick-prev:before,
#contents .lp-wrapper .space-slider-wrap .slick-next:before {
  display: block;
  font-family: system-ui, -apple-system, "Segoe UI", "Hiragino Sans", sans-serif;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 2.25rem;
  width: 100%;
  text-align: center;
  color: var(--lp-surface-base);
  opacity: 1;
}

#contents .lp-wrapper .space-slider-wrap .slick-prev:before {
  content: '\2039';
}

#contents .lp-wrapper .space-slider-wrap .slick-next:before {
  content: '\203A';
}

/* ----- SECTION 4 アクセス（ブランド色・フル幅帯） ----- */
#contents .lp-wrapper #section4 {
  background: var(--lp-brand);
}

#contents .lp-wrapper #section4 .section-label {
  color: rgba(255, 255, 255, 0.95);
  border-color: var(--lp-border-muted);
}

#contents .lp-wrapper #section4 .section-heading,
#contents .lp-wrapper #section4 .section-lead {
  color: rgba(255, 255, 255, 0.94);
}

#contents .lp-wrapper #section4 .assurance-list li {
  color: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 2px;
  margin-bottom: 1em;
  box-sizing: border-box;
  padding: 0.9rem 1em;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.35em;
  text-align: center;
    font-size: 0.9rem;
}

#contents .lp-wrapper #section4 .assurance-list li:last-child {
  margin-bottom: 0;
}

#contents .lp-wrapper #section4 .assurance-list li::before {
  color: var(--lp-accent-line);
  position: static;
  flex-shrink: 0;
}

#contents .lp-wrapper #section4 .btn-secondary {
  color: var(--lp-surface-base);
  border-color: rgba(255, 255, 255, 0.9);
}

#contents .lp-wrapper .facility-block {
  border: 1px solid #ddd;
  background: var(--lp-surface-base);
  padding: 1.25em;
  margin: 0 0 1.75em;
}

#contents .lp-wrapper .facility-name {
  font-size: 1rem;
  font-weight: 700;
  color: var(--lp-text);
  margin: 0 0 0.375em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .facility-name {
    font-size: 1rem;
  }
}

#contents .lp-wrapper .facility-address {
  font-size: 0.9rem;
  color: #565656;
  margin: 0 0 1em;
  line-height: 1.6;
}


#contents .lp-wrapper .facility-tel {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--lp-text);
  margin: 0 0 0.25em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .facility-tel {
    font-size: 1rem;
  }
}

#contents .lp-wrapper .map-embed {
  position: relative;
  width: 100%;
  margin: 0 0 1em;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  background: #e8e8e8;
}

#contents .lp-wrapper .map-embed iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

#contents .lp-wrapper .access-route-grid {
  display: block;
}

@media (min-width: 976px) {
  #contents .lp-wrapper .access-route-grid {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 1em 2.25em;
    align-items: start;
  }

  #contents .lp-wrapper .access-route-col {
    min-width: 0;
  }
}

#contents .lp-wrapper .facility-h3 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--lp-text);
  margin: 1em 0 0.375em;
}

#contents .lp-wrapper .facility-h3-icon-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
}

#contents .lp-wrapper .facility-h3-icon {
  width: 1.05em;
  height: 1.05em;
  fill: currentColor;
  flex-shrink: 0;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .facility-h3 {
    font-size: 1rem;
  }
}

#contents .lp-wrapper .access-info {
  font-size: 0.9rem;
  line-height: 1.75;
  color: var(--lp-text-subtle);
  margin: 0;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .access-info {
    font-size: 1rem;
    color: var(--lp-text);
  }
}

#contents .lp-wrapper .assurance-list {
  list-style: none;
  margin: 0 0 2em;
  padding: 0;
}

#contents .lp-wrapper .assurance-list li {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--lp-brand);
  padding: 0.8125em 0 0.8125em 1.625em;
  border-bottom: 1px solid #e5e5e5;
  position: relative;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .assurance-list li {
    font-size: 1rem;
  }
}

#contents .lp-wrapper .assurance-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--lp-accent-line);
  font-weight: 700;
}

#contents .lp-wrapper .assurance-list li:last-child {
  border-bottom: none;
}

@media (min-width: 976px) {
  #contents .lp-wrapper .assurance-list {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-evenly;
    align-items: stretch;
    gap: 2em;
  }

  #contents .lp-wrapper .assurance-list li {
    flex: 1 1 0;
    min-width: 0;
    border-bottom: none;
    padding: 0.9rem 1em;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 0.35em;
    text-align: center;
  }

  #contents .lp-wrapper .assurance-list li::before {
    position: static;
    flex-shrink: 0;
  }

  #contents .lp-wrapper #section4 .assurance-list li {
    margin-bottom: 0;
  }
}

#contents .lp-wrapper .final-cta-main {
  margin-top: 2.5em;
}

#contents .lp-wrapper .final-cta-main .btn-primary {
  padding: 1.375em 1.25em;
  font-size: 1rem;
}

#contents .lp-wrapper .final-cta-secondary {
  margin-top: 0.75em;
}

/* ----- SECTION 5（v5: 幅ボックス・背景は基本色＝白） ----- */
#contents .lp-wrapper #section5 {
  background: var(--lp-surface-base);
}

@media (min-width: 976px) {
  #contents .lp-wrapper #section5 .section-label.pcTxtCenter {
    display: table;
    margin-left: auto;
    margin-right: auto;
  }
}

#contents .lp-wrapper .section-img {
  margin-top: 1.5em;
  margin-bottom: 0;
}

@media (min-width: 976px) {
  #contents .lp-wrapper #section5 .section5-media-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5em;
    align-items: center;
    margin-top: 1.5em;
  }

  #contents .lp-wrapper #section5 .section5-media-row .section-img {
    order: 2;
    margin: 0;
  }

  #contents .lp-wrapper #section5 .section5-media-row .section-lead {
    order: 1;
    margin: 0;
  }

  #contents .lp-wrapper #section5 .section5-media-row + .lp-cta-tablet {
    margin-top: 1.5em;
  }
}

/* ----- SECTION 6 性能（濃い背景色・フル幅帯） ----- */
#contents .lp-wrapper #section6 {
  background: var(--lp-surface-deep);
}

#contents .lp-wrapper #section6 .section-label {
  color: rgba(255, 255, 255, 0.95);
  border-color: var(--lp-border-muted);
}

#contents .lp-wrapper #section6 .section-heading,
#contents .lp-wrapper #section6 .section-lead {
  color: rgba(255, 255, 255, 0.92);
}

#contents .lp-wrapper .perf-grid {
  display: block;
  margin: 2em 0 1em;
}

@media (min-width: 1100px) {
  #contents .lp-wrapper .perf-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1em 1.25em;
    align-items: stretch;
  }

  #contents .lp-wrapper .perf-grid .perf-block {
    margin: 0;
    height: 100%;
    display: flex;
    flex-direction: column;
  }

  #contents .lp-wrapper .perf-grid .perf-block-body {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
  }

  #contents .lp-wrapper .perf-grid .perf-text {
    flex: 1 1 auto;
  }

  #contents .lp-wrapper .perf-grid .perf-logo {
    margin-top: auto;
  }
}

#contents .lp-wrapper .perf-block {
  border: 1px solid #e8e8e8;
  padding: 0 0 1.5em;
  margin: 0 0 1.5em;
  overflow: hidden;
  background: var(--lp-surface-base);
}

/* 画像はブロック内で左右はみ出し防止 */
#contents .lp-wrapper .perf-block img,
#contents .lp-wrapper .space-card-img,
#contents .lp-wrapper .terrace-img {
  max-width: 100%;
  height: auto;
}

#contents .lp-wrapper .perf-block-img {
  width: 100%;
  display: block;
  max-height: 15rem;
  object-fit: cover;
  object-position: center top;
  margin: 0 0 1.25em;
  background: #eee;
}

#contents .lp-wrapper .perf-block-img--contain {
  object-fit: contain;
  background: #f0f0f0;
  max-height: 18rem;
}

#contents .lp-wrapper .perf-block-img--cover {
  object-fit: cover;
}

#contents .lp-wrapper .perf-block-body {
  padding: 0 1.25em;
}

#contents .lp-wrapper .perf-heading {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.42;
  color: var(--lp-text);
  margin: 0 0 0.625em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper .perf-heading {
    font-size: 1.25rem;
  }
}

#contents .lp-wrapper .perf-text {
  line-height: 1.8;
  margin: 0;
}

#contents .lp-wrapper .perf-text small {
  font-size: 0.75rem;
  color: #565656;
}


/* .perf-block img より詳細度を上げて max-width を効かせる（地震あんしん保証・エアロハス等） */
#contents .lp-wrapper .perf-block img.perf-logo {
  display: block;
  max-width: 240px;
  width: 100%;
  height: auto;
  margin: 1em auto 0;
  box-sizing: border-box;
}

#contents .lp-wrapper .section-cta-wrap {
  padding: 2em 0 0.5em;
}

/* ----- SECTION 7（ブランド色・フル幅帯・ブルーグレー装飾） ----- */
#contents .lp-wrapper #section7.cta-variant {
  background: var(--lp-brand);
  border-top: 4px solid var(--lp-border-muted);
}

#contents .lp-wrapper #section7 .final-cta-heading {
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.95);
  margin: 0 0 1em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper #section7 .final-cta-heading {
    font-size: 1.5rem;
  }
}

#contents .lp-wrapper #section7 .final-cta-sub {
  font-size: 0.9rem;
  line-height: 1.85;
  color: rgba(255, 255, 255, 0.88);
  margin: 0 0 1em;
}

#contents .lp-wrapper #section7 p.final-cta-sub:last-of-type {
  margin-bottom: 2.25em;
}

@media (min-width: 1025px) {
  #contents .lp-wrapper #section7 .final-cta-sub {
    font-size: 1rem;
    color: rgba(255, 255, 255, 0.9);
  }
}

#contents .lp-wrapper #section7 .btn-secondary {
  color: var(--lp-surface-base);
  border-color: rgba(255, 255, 255, 0.9);
}

#contents .lp-wrapper .share-sns-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45em;
  align-items: stretch;
}

#contents .lp-wrapper .btn-secondary.btn-share-sns {
  width: 100%;
  max-width: none;
  margin: 0;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: 0;
  padding: 0.55em 0.35em;
  border: 1px solid currentColor;
  transition: opacity 0.2s ease;
}

#contents .lp-wrapper .btn-secondary.btn-share-sns:hover {
  opacity: 0.5;
}

@media (min-width: 976px) {
  #contents .lp-wrapper #section7 .section-img {
    max-width: 768px;
    margin-left: auto;
    margin-right: auto;
  }
}
