/* TAKAOKA v0.3.5 failsafe */

/* Clear WordPress error-page body style if it leaks into the normal template */
html body.page-template-page-contact,
html body.page-template-page-contact#error-page {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  background: #f4f6f9 !important;
}

html body.page-template-page-contact .site-header,
html body.page-template-page-contact main,
html body.page-template-page-contact .site-footer {
  width: 100% !important;
  max-width: none !important;
}

/* Header stable two-row layout */
.site-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  width: 100% !important;
  background: rgba(255,255,255,.98) !important;
  border-bottom: 1px solid rgba(221,225,230,.9) !important;
}

.admin-bar .site-header {
  top: 32px !important;
}

.site-header__inner {
  width: min(1180px, calc(100% - 48px)) !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 16px 0 13px !important;
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  grid-template-areas: "brand cta" "nav nav" !important;
  align-items: center !important;
  justify-content: space-between !important;
  row-gap: 12px !important;
  column-gap: 24px !important;
}

.site-logo {
  grid-area: brand !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-self: start !important;
  width: auto !important;
  height: auto !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  writing-mode: horizontal-tb !important;
  transform: none !important;
}

.site-logo__text {
  display: inline-flex !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
  font-size: 20px !important;
  line-height: 1 !important;
  letter-spacing: .18em !important;
  color: #111820 !important;
}

.header-cta {
  grid-area: cta !important;
  justify-self: end !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 42px !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  background: #ff6a00 !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  writing-mode: horizontal-tb !important;
}

.site-nav {
  grid-area: nav !important;
  position: static !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
  background: transparent !important;
  border: 0 !important;
}

.site-nav__list,
.site-menu,
.primary-menu {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 12px 22px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.site-nav__list > li,
.site-menu > li,
.primary-menu > li {
  flex: 0 0 auto !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.site-nav a,
.site-menu a,
.primary-menu a {
  display: inline-flex !important;
  align-items: center !important;
  padding: 0 !important;
  color: #111820 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
  writing-mode: horizontal-tb !important;
  text-orientation: mixed !important;
}

/* Contact page layout */
.page-template-page-contact .contact-hero-compact {
  padding: clamp(64px, 7vw, 96px) 0 clamp(40px, 5vw, 70px) !important;
}

.page-template-page-contact .contact-page-intro-section {
  background: #fff !important;
  padding: clamp(46px, 6vw, 86px) 0 !important;
}

.page-template-page-contact .contact-form-section {
  background: #f4f6f9 !important;
  padding: clamp(46px, 6vw, 86px) 0 !important;
}

.page-template-page-contact .contact-page-intro-card,
.page-template-page-contact .contact-form-shell {
  border: 1px solid #d8dee6 !important;
  border-radius: 28px !important;
  background: #fff !important;
  box-shadow: 0 18px 44px rgba(8,10,13,.06) !important;
}

.page-template-page-contact .contact-page-intro-card {
  padding: clamp(28px, 4vw, 48px) !important;
}

.page-template-page-contact .contact-form-shell {
  padding: clamp(24px, 4vw, 44px) !important;
}

.page-template-page-contact .contact-form-shell .takaoka-contact {
  max-width: none !important;
  margin: 0 !important;
}

.takaoka-form-missing-notice {
  padding: 24px;
  border: 1px solid #f2b7b7;
  border-radius: 18px;
  background: #fff1f1;
  color: #a32222;
}

.takaoka-form-missing-notice p {
  margin: 0;
  line-height: 1.8;
}

.takaoka-form-missing-notice p + p {
  margin-top: 6px;
}

@media (max-width: 760px) {
  .site-header__inner {
    width: min(100% - 32px, 1180px) !important;
    grid-template-columns: 1fr !important;
    grid-template-areas: "brand" "cta" "nav" !important;
    justify-items: center !important;
  }

  .site-logo,
  .header-cta {
    justify-self: center !important;
  }

  .site-nav__list,
  .site-menu,
  .primary-menu {
    gap: 10px 14px !important;
  }

  .page-template-page-contact .contact-page-intro-card,
  .page-template-page-contact .contact-form-shell {
    border-radius: 20px !important;
  }
}


/* v0.3.6 text and card refinements */
.dealer-notice__body p { white-space: pre-line; }
.spec-cta__small { line-height: 1.9 !important; }
.product-card__content p,
.doc-card__body p,
.related-card p { line-height: 1.85 !important; }
.product-caution p { white-space: pre-line; }
.doc-empty { grid-column: 1 / -1; }
@media (max-width: 760px) {
  .product-detail-hero__grid,
  .container.two-col { grid-template-columns: 1fr !important; }
}
