@charset "UTF-8";
/* Kizuna Gaiheki — Navy + Gold theme refresh */

:root {
  --kg-navy: #0f2744;
  --kg-navy-dark: #0a1929;
  --kg-navy-mid: #1a3a5c;
  --kg-navy-light: #2a4f73;
  --kg-gold: #c9a227;
  --kg-gold-light: #e8c547;
  --kg-gold-dark: #a6851e;
  --kg-cream: #f8f6f2;
  --kg-cream-dark: #ede9e1;
  --kg-text: #1a2a3a;
  --kg-text-muted: #5a6a7a;
  --kg-white: #ffffff;
  --font-sans: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  --font-serif: "Noto Serif JP", "Hiragino Mincho ProN", "Yu Mincho", serif;
}

/* ---- Base typography ---- */
body {
  font-family: var(--font-sans);
  color: var(--kg-text);
  background-color: var(--kg-cream);
}

h1, h2, h3, h4, h5, h6,
.large-title,
.inquiry-ttl,
.index--service-title {
  font-family: var(--font-serif);
}

/* ---- Header accent bar ---- */
.header-accent {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--kg-gold-dark), var(--kg-gold), var(--kg-gold-light), var(--kg-gold));
  z-index: 9999;
}

/* ---- Header ---- */
#header.header {
  box-shadow: 0 2px 16px rgba(15, 39, 68, 0.08);
}

.logo-name {
  color: var(--kg-gold-light);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  margin-top: 0.3em;
  line-height: 1.3;
}

@media screen and (max-width: 750px) {
  .logo-name {
    color: var(--kg-navy);
    font-size: 2.4vw;
    text-align: center;
  }
}

/* ---- Navigation ---- */
.navi-menu-en {
  color: var(--kg-gold) !important;
  font-family: var(--font-sans);
  letter-spacing: 0.12em;
}

.navi-menu-jp {
  color: var(--kg-navy);
  font-weight: 600;
}

@media screen and (min-width: 751px) {
  .navi-menu:hover:after {
    border-color: var(--kg-gold) transparent transparent transparent !important;
  }

  .navi-submenu-list a:hover {
    color: var(--kg-gold) !important;
  }
}

/* ---- Toggle (mobile menu) ---- */
#header.header--refresh .toggle > span:not(.toggle-text) {
  background-color: var(--kg-navy) !important;
}

#header.header--refresh .toggle .toggle-text {
  width: auto !important;
  height: auto !important;
  background: none !important;
  background-color: transparent !important;
}

.toggle-text {
  color: var(--kg-navy);
}

/* ---- Header CTA buttons ---- */
.header-inquiry-reserve a,
.header-inquiry-cta-btn,
.inquiry-reserve a {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-gold) !important;
  border-radius: 6px !important;
}

.header-inquiry-reserve a p:nth-child(1),
.header-inquiry-cta-btn__badge,
.inquiry-reserve a p:nth-child(1) {
  background-color: var(--kg-gold) !important;
  color: var(--kg-navy) !important;
  border-radius: 2px;
}

.header-inquiry-reserve a p:nth-child(2),
.header-inquiry-cta-btn__label,
.inquiry-reserve a p:nth-child(2) {
  color: var(--kg-white) !important;
}

@media screen and (min-width: 751px) {
  .header-inquiry-reserve a:hover,
  .header-inquiry-cta-btn:hover {
    background-color: var(--kg-navy-mid) !important;
    border-color: var(--kg-gold-light) !important;
  }

  .header-inquiry-reserve a:hover p:nth-child(2),
  .header-inquiry-cta-btn:hover .header-inquiry-cta-btn__label {
    color: var(--kg-gold-light) !important;
  }
}

/* ---- Header drawer inquiry (mobile) ---- */
#header.header--refresh .header-inquiry-reserve a::after,
#header.header--refresh .header-inquiry-contact-btn::after,
#header.header--refresh .header-inquiry-phone-card::before,
#header.header--refresh .header-inquiry-phone-card::after {
  display: none !important;
}

#header.header--refresh .header-inquiry-cta-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: auto !important;
  padding: 16px 20px;
  text-decoration: none;
  border: 2px solid var(--kg-gold) !important;
  box-shadow: 0 4px 16px rgba(15, 39, 68, 0.2) !important;
  transition: background-color 0.2s, border-color 0.2s;
}

#header.header--refresh .header-inquiry-cta-btn__badge {
  display: inline-block;
  padding: 4px 10px;
  background-color: var(--kg-gold) !important;
  color: var(--kg-navy) !important;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.3;
  border-radius: 2px;
}

#header.header--refresh .header-inquiry-cta-btn__body {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

#header.header--refresh .header-inquiry-cta-btn__icon {
  flex-shrink: 0;
  width: 22px;
  height: 24px;
  background: url(../img/common/loupe-wh.svg) center / contain no-repeat;
}

#header.header--refresh .header-inquiry-cta-btn__label {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.2;
}

#header.header--refresh .header-inquiry-contact-btn {
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: auto !important;
  min-height: 52px;
  padding: 12px 14px !important;
  border-width: 2px !important;
  border-style: solid !important;
  border-radius: 6px !important;
  box-shadow: none !important;
  text-decoration: none;
  transition: background-color 0.2s, border-color 0.2s, color 0.2s;
}

#header.header--refresh .header-inquiry-contact-btn span:last-child {
  color: var(--kg-white);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
}

#header.header--refresh .header-inquiry-contact-btn__icon {
  flex-shrink: 0;
  width: 18px;
  height: 14px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

#header.header--refresh .header-inquiry-contact-btn__icon--mail {
  background-image: url(../img/common/mail-wh.svg);
}

#header.header--refresh .header-inquiry-contact-btn__icon--line {
  width: 20px;
  height: 18px;
  background-image: url(../img/common/chat-wh.svg);
}

#header.header--refresh .header-inquiry-btn--mail.header-inquiry-contact-btn {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

#header.header--refresh .header-inquiry-btn--line.header-inquiry-contact-btn {
  background-color: #2d8a3e !important;
  border-color: #2d8a3e !important;
}

#header.header--refresh .header-inquiry-phone-card {
  display: block;
  width: 100%;
  padding: 18px 16px;
  text-decoration: none;
  text-align: center;
  background-color: var(--kg-cream);
  border: 2px solid var(--kg-navy);
  border-radius: 6px;
  transition: background-color 0.2s, border-color 0.2s;
}

#header.header--refresh .header-inquiry-phone-card__lead {
  display: inline-block;
  margin: 0 auto 14px;
  padding: 6px 12px;
  background-color: var(--kg-gold);
  color: var(--kg-navy);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.45;
  border-radius: 2px;
}

#header.header--refresh .header-inquiry-phone-card__main {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

#header.header--refresh .header-inquiry-phone-card__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 8px;
  background-color: var(--kg-white);
  border: 1px solid var(--kg-navy);
  color: var(--kg-text-muted);
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
  border-radius: 4px;
}

#header.header--refresh .header-inquiry-phone-card__number {
  font-family: var(--font-serif);
  font-size: 28px;
  font-weight: 700;
  color: var(--kg-navy);
  letter-spacing: 0.02em;
  line-height: 1.1;
}

#header.header--refresh .header-inquiry-phone-card__hours {
  margin: 12px 0 0;
  color: var(--kg-text-muted);
  font-size: 11px;
  line-height: 1.4;
}

#header.header--refresh .header-inquiry-phone-card__hours span {
  color: var(--kg-navy);
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  #header.header--refresh .header-inquiry {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 28px auto 0 !important;
    width: 100% !important;
    background-color: var(--kg-white);
    border-left: 4px solid var(--kg-gold);
    border-radius: 8px;
    box-shadow: 0 8px 28px rgba(10, 25, 41, 0.15);
    overflow: visible;
  }

  #header.header--refresh .header-inquiry > div:nth-child(n+2) {
    margin-top: 0 !important;
  }

  #header.header--refresh .header-inquiry-reserve {
    order: 1;
    width: 100% !important;
    margin: 0 !important;
    padding: 16px 16px 10px;
    background: linear-gradient(180deg, rgba(15, 39, 68, 0.04) 0%, transparent 100%);
  }

  #header.header--refresh .header-inquiry-btn {
    order: 2;
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 16px 16px;
    width: 100% !important;
  }

  #header.header--refresh .header-inquiry-btn a:nth-child(n+2) {
    margin-top: 0 !important;
  }

  #header.header--refresh .header-inquiry-contact-btn {
    flex-direction: column !important;
    gap: 6px !important;
    min-height: 72px;
    padding: 12px 8px !important;
    border-radius: 8px !important;
  }

  #header.header--refresh .header-inquiry-contact-btn span:last-child {
    font-size: 13px;
  }

  #header.header--refresh .header-inquiry-tel--drawer {
    order: 3;
    position: relative;
    z-index: 1;
    margin: 0 !important;
    padding: 0 16px 16px;
    border-top: 1px solid var(--kg-cream-dark);
    padding-top: 16px;
  }

  #header.header--refresh .header-inquiry-tel--drawer a,
  #header.header--refresh .header-inquiry-phone-card {
    display: block !important;
    position: relative !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 18px 16px !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    background-color: var(--kg-cream) !important;
    border: 2px solid var(--kg-navy) !important;
    border-radius: 8px !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  #header.header--refresh .header-inquiry-tel--drawer a::before {
    display: none !important;
    content: none !important;
  }

  #header.header--refresh .header-inquiry-cta-btn {
    min-height: 88px;
    padding: 18px 16px;
    border-radius: 8px !important;
  }

  #header.header--refresh .header-inquiry-cta-btn__badge {
    font-size: 12px;
  }

  #header.header--refresh .header-inquiry-cta-btn__label {
    font-size: 20px;
  }

  #header.header--refresh .header-inquiry-phone-card {
    border-radius: 8px;
  }

  #header.header--refresh .header-inquiry-phone-card__number {
    font-size: 30px;
  }
}

.header-inquiry-tel-balloon {
  background-color: var(--kg-gold) !important;
  color: var(--kg-navy) !important;
}

.header-inquiry-tel-balloon:after {
  border-color: var(--kg-gold) transparent transparent transparent !important;
}

.header-inquiry-tel-balloon span {
  color: var(--kg-navy);
}

@media screen and (min-width: 751px) {
  .header-inquiry-tel-ttl {
    background-color: var(--kg-gold) !important;
    color: var(--kg-navy) !important;
  }

  .header-inquiry-tel a {
    border-color: var(--kg-navy) !important;
  }
}

/* ---- Hero section ---- */
#hero-image {
  position: relative;
}

#hero-image .hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(10, 25, 41, 0.72) 0%,
    rgba(15, 39, 68, 0.45) 50%,
    rgba(10, 25, 41, 0.65) 100%
  );
  z-index: 1;
  pointer-events: none;
}

#hero-image #main-text {
  position: relative;
  z-index: 2;
}

#hero-image h2,
#hero-image #main-text-ja {
  font-family: var(--font-serif);
  font-weight: 600;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.4);
  letter-spacing: 0.06em;
}

#hero-image h2::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: linear-gradient(90deg, var(--kg-gold), var(--kg-gold-light));
  margin-top: 20px;
}

@media screen and (max-width: 575px) {
  #hero-image h2::after {
    width: 40px;
    margin-top: 12px;
  }
}

/* ---- Section titles (kyomura) ---- */
#page .large-title {
  color: var(--kg-gold) !important;
  font-family: var(--font-serif);
  letter-spacing: 0.15em;
}

#page #index--service .bg-service:before {
  background-color: var(--kg-cream-dark) !important;
}

#page #index--service .index--service-title {
  color: var(--kg-navy);
  border-left: 3px solid var(--kg-gold);
  padding-left: 12px;
}

/* ---- Inquiry / CTA block ---- */
.inquiry:before {
  background: repeating-linear-gradient(
    135deg,
    var(--kg-navy),
    var(--kg-navy) 2.6666666667vw,
    var(--kg-navy-mid) 2vw,
    var(--kg-navy-mid) 4.6666666667vw
  ) !important;
}

.inquiry-ttl span {
  color: var(--kg-gold-light);
}

.inquiry-box {
  border: none;
  border-left: 4px solid var(--kg-gold);
  border-radius: 8px !important;
  box-shadow: 0 12px 40px rgba(10, 25, 41, 0.2);
}

/* ---- Footer ---- */
.footer,
#site-footer.footer {
  background-color: var(--kg-navy-dark) !important;
}

.footer-data dl dt:after {
  border-color: transparent transparent transparent var(--kg-gold) !important;
}

/* ---- Generic color overrides (cyan → navy/gold) ---- */
[style*="#1ba6e0"],
[style*="#0099ce"] {
  /* inline styles fallback — none expected */
}

/* Buttons & links */
.btn-primary,
input[type="submit"],
.btn--primary {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

.btn-primary:hover,
input[type="submit"]:hover {
  background-color: var(--kg-navy-mid) !important;
  border-color: var(--kg-gold) !important;
}

/* Broad cyan → navy override for common patterns */
.header-inquiry-reserve a,
.inquiry-reserve a,
.inquiry-btn--mail,
.header-inquiry-btn a {
  transition: background-color 0.25s, border-color 0.25s, color 0.25s;
}

/* Sub-page overrides */
.sub-ttl span,
.sub-navi a.is-active,
.breadcrumb a:hover,
.pager a.is-active,
.faq-list dt.is-open,
.flow-step-num,
.price-table th,
.company-table th,
.works-cat a.is-active,
.post-cat a,
.tag-list a {
  color: var(--kg-gold) !important;
}

.sub-ttl:before,
.faq-list dt.is-open:before,
.flow-step-num,
.price-table th,
.company-table th,
.works-cat a.is-active,
.post-cat a,
.tag-list a {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

/* Estatering3 section */
#estatering3 .promiseWrap {
  background-color: var(--kg-cream) !important;
}

#estatering3 [style*="background-color: #1ba6e0"],
#estatering3 .bg-primary {
  background-color: var(--kg-navy) !important;
}

/* Front page first section label */
.sec--first .first-label {
  background-color: var(--kg-navy) !important;
}

.sec--first .first-label span {
  color: var(--kg-gold-light) !important;
}

/* Swiper pagination */
.swiper-pagination-bullet-active {
  background-color: var(--kg-gold) !important;
}

/* Form focus */
input:focus,
textarea:focus,
select:focus {
  border-color: var(--kg-gold) !important;
  outline-color: var(--kg-gold) !important;
}

/* ---- Responsive inquiry stripe ---- */
@media screen and (min-width: 751px) {
  .inquiry:before {
    background: repeating-linear-gradient(
      135deg,
      var(--kg-navy),
      var(--kg-navy) 1.3888888889vw,
      var(--kg-navy-mid) 1.0416666667vw,
      var(--kg-navy-mid) 2.4305555556vw
    ) !important;
  }
}

@media screen and (min-width: 1441px) {
  .inquiry:before {
    background: repeating-linear-gradient(
      135deg,
      var(--kg-navy),
      var(--kg-navy) 20px,
      var(--kg-navy-mid) 15px,
      var(--kg-navy-mid) 35px
    ) !important;
  }
}

/* ---- Buttons ---- */
.btn-main--bl {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

.btn-main--wh {
  border-color: var(--kg-navy) !important;
}

.btn-main--ye {
  background-color: var(--kg-gold) !important;
  border-color: var(--kg-gold) !important;
}

.btn-main--ye span {
  color: var(--kg-navy) !important;
}

/* ---- Section headers ---- */
.sec-en {
  color: var(--kg-gold) !important;
  font-family: var(--font-serif) !important;
  font-weight: 600 !important;
  font-style: normal !important;
  letter-spacing: 0.2em !important;
}

.sec-ttl span {
  color: var(--kg-gold) !important;
}

.new {
  background-color: var(--kg-gold) !important;
  color: var(--kg-navy) !important;
  font-family: var(--font-serif) !important;
  font-style: normal !important;
}

/* ---- Flow section ---- */
.flow-num {
  background-color: var(--kg-navy) !important;
  font-family: var(--font-serif) !important;
}

.flow-ttl {
  color: var(--kg-navy) !important;
}

@media screen and (max-width: 750px) {
  .flow:before {
    background-color: var(--kg-gold) !important;
  }
}

/* ---- Footer nav hover ---- */
.footer-navi-menu li a:hover,
.footer-navi-head a:hover,
.footer-navi-child li a:hover {
  color: var(--kg-gold) !important;
}

/* ---- Fix CTA bar ---- */
.fix-cta-reserve a {
  background-color: var(--kg-navy) !important;
}

.fix-cta-reserve a p:nth-child(1) {
  background-color: var(--kg-gold) !important;
  color: var(--kg-navy) !important;
}

/* ---- Area / works sections ---- */
.area-ttl span,
.works-ttl span {
  color: var(--kg-gold) !important;
}

.area-map-ttl,
.works-cat-ttl {
  color: var(--kg-navy) !important;
}

/* ---- Blog cards ---- */
.blog-cat {
  background-color: var(--kg-navy) !important;
}

.blog-date span {
  color: var(--kg-gold) !important;
}

/* ---- Drawer (mobile) ---- */
@media screen and (max-width: 750px) {
  .header-drawer {
    background-color: var(--kg-cream) !important;
  }
}

/* ---- Sub page title (.ttl-en) ---- */
.ttl-en {
  color: var(--kg-gold) !important;
}

/* ---- Sub pages: accent color sweep ---- */
.sub-ttl,
.sub-ttl span,
.pager-num.is-active,
.pager-arrow:hover,
.breadcrumb li a:hover,
.side-navi a.is-active,
.side-navi a:hover,
.post-ttl a:hover,
.works-list-cat,
.single-work-info dt,
.company-map-ttl,
.faq-ttl span,
.price-ttl span,
.flow-list-num,
.reserve-step.is-active .reserve-step-num {
  color: var(--kg-gold) !important;
}

.sub-ttl::before,
.pager-num.is-active,
.side-navi a.is-active::before,
.flow-list-num,
.reserve-step.is-active .reserve-step-num,
.faq-list dt::before {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

input[type="submit"],
.wpcf7-submit,
.form-btn input {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

input[type="submit"]:hover,
.wpcf7-submit:hover,
.form-btn input:hover {
  background-color: var(--kg-navy-mid) !important;
  border-color: var(--kg-gold) !important;
}

/* ---- #area 施工エリア ---- */
.sec--area {
  padding: 48px 0 56px;
  background: linear-gradient(180deg, var(--kg-cream) 0%, var(--kg-white) 100%);
}

.sec--area .sec-in {
  width: 92vw;
  max-width: 1000px;
}

#area .area {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin: 0 auto;
  padding: 28px 20px;
  background-color: var(--kg-white);
  border: none;
  border-left: 4px solid var(--kg-gold);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(15, 39, 68, 0.1);
}

#area .area-content {
  text-align: center;
  width: 100%;
}

#area .area-head {
  margin-bottom: 20px;
}

#area .area-en {
  color: var(--kg-gold);
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0.35em;
}

#area .area-ttl {
  margin-top: 8px;
  color: var(--kg-navy);
  font-family: var(--font-serif);
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.3;
}

#area .area-lead {
  margin-top: 12px;
  color: var(--kg-text-muted);
  font-size: 14px;
  line-height: 1.7;
  letter-spacing: 0.04em;
}

#area .area-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

#area .area-tags li {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 64px;
  padding: 8px 14px;
  background-color: var(--kg-navy);
  color: var(--kg-white);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  border-radius: 4px;
  border: 1px solid var(--kg-navy);
  transition: background-color 0.2s, color 0.2s, border-color 0.2s;
}

#area .area-tags li:hover {
  background-color: var(--kg-white);
  color: var(--kg-navy);
  border-color: var(--kg-gold);
}

#area .area-note {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--kg-cream-dark);
  color: var(--kg-text-muted);
  font-size: 12px;
  line-height: 1.6;
  letter-spacing: 0.02em;
}

#area .area-note::before {
  content: "※ ";
  color: var(--kg-gold);
}

#area .area-map {
  margin: 0;
  width: 100%;
}

#area .area-map-frame {
  overflow: hidden;
  border: 2px solid var(--kg-gold);
  border-radius: 6px;
  background-color: var(--kg-cream-dark);
  box-shadow: inset 0 0 0 1px rgba(15, 39, 68, 0.06);
}

#area .area-map-frame img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

/* hide legacy area elements if present */
#area .area-target,
#area .area-desc {
  display: none;
}

@media screen and (min-width: 751px) {
  .sec--area {
    padding: 64px 0 80px;
  }

  #area .area {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 40px;
    padding: 36px 40px;
    width: 100%;
    max-width: 910px;
  }

  #area .area-content {
    flex: 1 1 55%;
    min-width: 0;
    text-align: left;
  }

  #area .area-head {
    display: block;
    margin-bottom: 24px;
  }

  #area .area-en {
    font-size: 13px;
  }

  #area .area-ttl {
    margin-top: 6px;
    margin-left: 0;
    font-size: 32px;
  }

  #area .area-lead {
    font-size: 15px;
  }

  #area .area-tags {
    justify-content: flex-start;
    gap: 10px;
  }

  #area .area-tags li {
    min-width: 72px;
    padding: 9px 16px;
    font-size: 14px;
  }

  #area .area-note {
    text-align: left;
    font-size: 13px;
  }

  #area .area-map {
    flex: 0 0 38%;
    max-width: 360px;
  }
}

@media screen and (min-width: 1441px) {
  #area .area {
    padding: 40px 48px;
  }

  #area .area-ttl {
    font-size: 36px;
  }
}

/* ---- Footer inquiry-box ---- */
#site-footer .inquiry-ttl {
  font-family: var(--font-serif);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}

#site-footer .inquiry-box {
  margin-top: 24px !important;
  padding: 0 !important;
  width: 92vw !important;
  max-width: 900px;
  background-color: var(--kg-white) !important;
  border: none !important;
  border-left: 4px solid var(--kg-gold) !important;
  border-radius: 8px !important;
  box-shadow: 0 12px 40px rgba(10, 25, 41, 0.2);
  overflow: hidden;
}

#site-footer .inquiry-box::before {
  display: none !important;
}

#site-footer .inquiry-box-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
}

#site-footer .inquiry-panel {
  margin: 0;
  padding: 0;
}

/* Reset legacy common.css hooks */
#site-footer .inquiry-reserve a::before,
#site-footer .inquiry-reserve a::after,
#site-footer .inquiry-contact-btn::before,
#site-footer .inquiry-contact-btn::after,
#site-footer .inquiry-phone-card::before,
#site-footer .inquiry-phone-card::after {
  display: none !important;
}

#site-footer .inquiry-reserve {
  width: 100%;
  margin-top: 0 !important;
}

#site-footer .inquiry-reserve a {
  height: auto !important;
  box-shadow: none;
}

/* ---- CTA: 現地調査 ---- */
#site-footer .inquiry-cta-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  height: auto !important;
  min-height: 0;
  padding: 16px 20px;
  text-decoration: none;
  background-color: var(--kg-navy) !important;
  border: 2px solid var(--kg-gold) !important;
  border-radius: 6px !important;
  box-shadow: 0 4px 16px rgba(15, 39, 68, 0.2) !important;
  transition: background-color 0.2s, border-color 0.2s;
}

#site-footer .inquiry-cta-btn:hover {
  background-color: var(--kg-navy-mid) !important;
  border-color: var(--kg-gold-light) !important;
}

#site-footer .inquiry-cta-btn__badge {
  display: inline-block;
  padding: 4px 10px;
  background-color: var(--kg-gold);
  color: var(--kg-navy);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: 2px;
  line-height: 1.3;
}

#site-footer .inquiry-cta-btn__body {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

#site-footer .inquiry-cta-btn__icon {
  flex-shrink: 0;
  width: 22px;
  height: 24px;
  background: url(../img/common/loupe-wh.svg) center / contain no-repeat;
}

#site-footer .inquiry-cta-btn__label {
  color: var(--kg-white);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.2;
}

#site-footer .inquiry-cta-btn:hover .inquiry-cta-btn__label {
  color: var(--kg-gold-light);
}

/* ---- Contact: メール / LINE ---- */
#site-footer .inquiry-contact-btn {
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: auto !important;
  min-height: 52px;
  padding: 12px 14px !important;
  border-width: 2px !important;
  border-style: solid !important;
  border-radius: 6px !important;
  box-shadow: none !important;
  text-decoration: none;
  transition: background-color 0.2s, border-color 0.2s, color 0.2s;
}

#site-footer .inquiry-contact-btn span:last-child {
  color: var(--kg-white);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
}

#site-footer .inquiry-contact-btn__icon {
  flex-shrink: 0;
  width: 18px;
  height: 14px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

#site-footer .inquiry-contact-btn__icon--mail {
  background-image: url(../img/common/mail-wh.svg);
}

#site-footer .inquiry-contact-btn__icon--line {
  width: 20px;
  height: 18px;
  background-image: url(../img/common/chat-wh.svg);
}

#site-footer .inquiry-btn--mail.inquiry-contact-btn {
  background-color: var(--kg-navy) !important;
  border-color: var(--kg-navy) !important;
}

#site-footer .inquiry-btn--mail.inquiry-contact-btn:hover {
  background-color: var(--kg-white) !important;
  border-color: var(--kg-navy) !important;
}

#site-footer .inquiry-btn--mail.inquiry-contact-btn:hover span:last-child {
  color: var(--kg-navy) !important;
}

#site-footer .inquiry-btn--mail.inquiry-contact-btn:hover .inquiry-contact-btn__icon--mail {
  background-image: url(../img/common/mail-bk.svg);
}

#site-footer .inquiry-btn--line.inquiry-contact-btn {
  background-color: #2d8a3e !important;
  border-color: #2d8a3e !important;
}

#site-footer .inquiry-btn--line.inquiry-contact-btn:hover {
  background-color: var(--kg-white) !important;
  border-color: #2d8a3e !important;
}

#site-footer .inquiry-btn--line.inquiry-contact-btn:hover span:last-child {
  color: #2d8a3e !important;
}

/* ---- Mobile phone card ---- */
#site-footer .inquiry-phone-card {
  display: block;
  width: 100%;
  padding: 18px 16px;
  text-decoration: none;
  text-align: center;
  background-color: var(--kg-cream);
  border: 2px solid var(--kg-navy);
  border-radius: 6px;
  transition: background-color 0.2s, border-color 0.2s;
}

#site-footer .inquiry-phone-card:hover {
  background-color: var(--kg-white);
  border-color: var(--kg-gold);
}

#site-footer .inquiry-phone-card__lead {
  display: inline-block;
  margin: 0 auto 14px;
  padding: 6px 12px;
  background-color: var(--kg-gold);
  color: var(--kg-navy);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.45;
  border-radius: 2px;
}

#site-footer .inquiry-phone-card__main {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

#site-footer .inquiry-phone-card__tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 8px;
  background-color: var(--kg-white);
  border: 1px solid var(--kg-navy);
  color: var(--kg-text-muted);
  font-size: 10px;
  font-weight: 700;
  line-height: 1.2;
  border-radius: 4px;
}

#site-footer .inquiry-phone-card__number {
  font-family: var(--font-serif);
  font-size: 28px;
  font-weight: 700;
  color: var(--kg-navy);
  letter-spacing: 0.02em;
  line-height: 1.1;
}

#site-footer .inquiry-phone-card__hours {
  margin: 12px 0 0;
  color: var(--kg-text-muted);
  font-size: 11px;
  line-height: 1.4;
}

#site-footer .inquiry-phone-card__hours span {
  color: var(--kg-navy);
  font-weight: 600;
}

/* ---- Footer inquiry: mobile layout ---- */
@media screen and (max-width: 750px) {
  #site-footer .inquiry {
    margin-top: 36px;
    padding: 0;
  }

  #site-footer .inquiry-ttl {
    font-size: 17px;
    line-height: 1.7;
  }

  #site-footer .inquiry-ttl span {
    display: block;
    margin-top: 6px;
    font-size: 22px;
    color: var(--kg-gold-light);
  }

  #site-footer .inquiry-box {
    margin-top: 18px !important;
    margin-left: auto;
    margin-right: auto;
    width: 92vw !important;
    max-width: none;
    border-radius: 10px !important;
    box-shadow: 0 8px 28px rgba(10, 25, 41, 0.18);
  }

  #site-footer .inquiry-box-inner {
    flex-direction: column;
    gap: 0;
    padding: 0;
  }

  #site-footer .inquiry-panel--reserve {
    order: 1;
    padding: 16px 16px 10px;
    background: linear-gradient(180deg, rgba(15, 39, 68, 0.04) 0%, transparent 100%);
  }

  #site-footer .inquiry-panel--contact {
    order: 2;
    padding: 0 16px 16px;
  }

  #site-footer .inquiry-panel--tel-sp {
    order: 3;
    padding: 0 16px 16px;
    border-top: 1px solid var(--kg-cream-dark);
    margin-top: 4px;
    padding-top: 16px;
  }

  #site-footer .inquiry-cta-btn {
    min-height: 88px;
    padding: 18px 16px;
    border-radius: 8px !important;
  }

  #site-footer .inquiry-cta-btn__badge {
    font-size: 12px;
  }

  #site-footer .inquiry-cta-btn__label {
    font-size: 20px;
  }

  #site-footer .inquiry-btn {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px !important;
    margin-top: 0 !important;
    width: 100% !important;
  }

  #site-footer .inquiry-contact-btn {
    flex-direction: column !important;
    gap: 6px !important;
    min-height: 72px;
    padding: 12px 8px !important;
    border-radius: 8px !important;
  }

  #site-footer .inquiry-contact-btn span:last-child {
    font-size: 13px;
  }

  #site-footer .inquiry-contact-btn__icon--line {
    width: 22px;
    height: 20px;
  }

  #site-footer .inquiry-phone-card {
    padding: 20px 14px;
    border-radius: 8px;
  }

  #site-footer .inquiry-phone-card__lead {
    font-size: 12px;
    max-width: 92%;
  }

  #site-footer .inquiry-phone-card__number {
    font-size: 30px;
  }
}

/* ---- Footer inquiry: desktop layout ---- */
@media screen and (min-width: 751px) {
  #site-footer .inquiry-box {
    margin-top: 20px !important;
    width: 88vw !important;
  }

  #site-footer .inquiry-box-inner {
    flex-direction: row;
    align-items: center;
    gap: 0;
    padding: 28px 32px;
  }

  #site-footer .inquiry-panel--tel {
    flex: 0 0 auto;
    min-width: 200px;
    padding-right: 28px;
    border-right: 1px solid var(--kg-cream-dark);
    text-align: left;
  }

  #site-footer .inquiry-tel-label {
    margin: 0;
    color: var(--kg-gold-dark);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.15em;
  }

  #site-footer .inquiry-tel-number {
    margin: 8px 0 0;
    font-family: var(--font-serif);
    font-size: 34px;
    font-weight: 700;
    line-height: 1.1;
  }

  #site-footer .inquiry-tel-number a {
    color: var(--kg-navy);
    text-decoration: none;
    transition: color 0.2s;
  }

  #site-footer .inquiry-tel-number a:hover {
    color: var(--kg-gold);
  }

  #site-footer .inquiry-panel--tel .inquiry-time {
    display: flex;
    justify-content: flex-start;
    gap: 6px;
    margin-top: 8px;
  }

  #site-footer .inquiry-panel--tel .inquiry-time dt,
  #site-footer .inquiry-panel--tel .inquiry-time dd {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 12px;
    color: var(--kg-text-muted);
  }

  #site-footer .inquiry-panel--reserve {
    flex: 0 1 auto;
    padding: 0 24px;
  }

  #site-footer .inquiry-cta-btn {
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 12px;
    min-height: 72px;
    padding: 14px 20px !important;
    min-width: 260px;
  }

  #site-footer .inquiry-cta-btn__badge {
    flex-shrink: 0;
    margin: 0;
  }

  #site-footer .inquiry-cta-btn__body {
    gap: 8px;
  }

  #site-footer .inquiry-cta-btn__label {
    font-size: 20px;
    white-space: nowrap;
  }

  #site-footer .inquiry-panel--contact {
    flex: 0 0 220px;
    margin-left: auto;
  }

  #site-footer .inquiry-btn {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    margin-top: 0 !important;
    width: 100% !important;
  }

  #site-footer .inquiry-contact-btn {
    flex-direction: row !important;
    min-height: 48px;
    padding: 0 16px 0 40px !important;
    justify-content: flex-start !important;
  }

  #site-footer .inquiry-contact-btn span:last-child {
    font-size: 14px;
  }
}

@media screen and (min-width: 1441px) {
  #site-footer .inquiry-box {
    max-width: 960px;
  }

  #site-footer .inquiry-box-inner {
    padding: 32px 40px;
  }

  #site-footer .inquiry-tel-number {
    font-size: 40px;
  }

  #site-footer .inquiry-panel--reserve {
    padding: 0 32px;
  }

  #site-footer .inquiry-cta-btn {
    min-width: 280px;
  }
}
