/**
 * PPF 価格ページ — sticky CTA お問い合わせポップアップ
 * 初期 HTML は空シェル（SEO: 本文の埋め込みフォームがクローラー向けコンテンツ）
 */

body.has-wrap-sticky-cta.modal-open .arc-ppf-sticky-modal.modal {
  z-index: 100050;
  display: flex !important;
  align-items: stretch;
  justify-content: center;
  padding-top: clamp(0.75rem, 3vw, 1.25rem) !important;
  padding-left: clamp(0.75rem, 4vw, 1.25rem) !important;
  padding-right: clamp(0.75rem, 4vw, 1.25rem) !important;
  padding-bottom: calc(var(--wrap-sticky-cta-height, 68px) + env(safe-area-inset-bottom, 0px)) !important;
  overflow: hidden !important;
}

body.has-wrap-sticky-cta.modal-open .arc-ppf-sticky-modal .modal-dialog {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  width: 100%;
  max-width: min(74rem, 100%);
  height: 100% !important;
  min-height: 0 !important;
  max-height: none !important;
  margin: 0 auto !important;
}

body.has-wrap-sticky-cta.modal-open .arc-ppf-sticky-modal .modal-content,
body.has-wrap-sticky-cta.modal-open .arc-ppf-sticky-modal .modal-body {
  background: var(--arc-brand-yellow, #ffe900) !important;
}

body.has-wrap-sticky-cta.modal-open .arc-ppf-sticky-modal .modal-content {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  height: 100%;
  max-height: none !important;
  overflow: hidden;
}

.arc-ppf-sticky-modal .modal-header,
.arc-ppf-sticky-modal .modal-title {
  display: none !important;
}

.arc-ppf-sticky-modal__content {
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 100%;
  height: 100%;
  background: var(--arc-brand-yellow, #ffe900) !important;
  border: none;
  border-radius: 0.75rem;
  overflow: hidden;
}

.arc-ppf-sticky-modal__close {
  position: absolute;
  top: 0.65rem;
  right: 0.75rem;
  z-index: 5;
  float: none;
  margin: 0;
  padding: 0.35rem 0.55rem;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1;
  color: #0d0d0d;
  opacity: 0.72;
  text-shadow: 0 0 0.35rem rgba(255, 255, 255, 0.65);
}

.arc-ppf-sticky-modal__close:hover,
.arc-ppf-sticky-modal__close:focus {
  opacity: 1;
  color: #0d0d0d;
}

.arc-ppf-sticky-modal__body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  height: 100%;
  padding: 0 !important;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  background: var(--arc-brand-yellow, #ffe900) !important;
}

.arc-ppf-sticky-modal__body .ppf-quote-section--modal {
  --ppf-gold: var(--arc-brand-yellow, #ffe900);
  --ppf-quote-text: #1a1a1a;
  --ppf-quote-muted: #424242;
  --ppf-quote-accent: #0d0d0d;
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  min-height: 100%;
  margin: 0;
  padding: clamp(2.75rem, 7vw, 3.25rem) clamp(1rem, 3vw, 1.75rem) clamp(1.75rem, 4vw, 2.5rem);
  background: var(--ppf-gold) !important;
  border: none;
  box-sizing: border-box;
}

.arc-ppf-sticky-modal__body .ppf-quote-section--modal .ppf-quote-inner {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  max-width: min(68.75rem, 100%);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.arc-ppf-sticky-modal__body .ppf-gravity-form-slot {
  flex: 1 1 auto;
  text-align: left;
}

.arc-ppf-sticky-modal__body .ppf-quote-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  max-width: min(45rem, 100%);
  margin: 0 auto clamp(1.5rem, 4vw, 2rem);
  padding: clamp(1.35rem, 4vw, 2rem) clamp(1.25rem, 4vw, 2rem);
  background: #0d0d0d !important;
  border: 0.125rem solid #0d0d0d;
  box-shadow: 0 0.625rem 2rem rgba(0, 0, 0, 0.2);
  box-sizing: border-box;
}

.arc-ppf-sticky-modal__body .ppf-quote-hero .ppf-quote-hero__badge,
.arc-ppf-sticky-modal__body .ppf-quote-hero p.ppf-quote-hero__badge {
  margin: 0 0 0.7rem;
  width: 100%;
  text-align: center !important;
  color: var(--ppf-gold) !important;
  font-size: clamp(1.35rem, 4.8vw, 1.95rem) !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em;
  line-height: 1.25 !important;
}

.arc-ppf-sticky-modal__body .ppf-quote-hero__title {
  margin: 0 !important;
  width: 100%;
  text-align: center !important;
  color: #fff !important;
  font-size: clamp(1.55rem, 5.8vw, 2.2rem) !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
  letter-spacing: 0.05em;
}

.arc-ppf-sticky-modal__body .ppf-quote-hero__title .ppf-price__cfa2-target {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  width: 100%;
  text-align: center !important;
}

.arc-ppf-sticky-modal__body .ppf-quote-hero__title .ppf-price__cfa2-char {
  text-align: center !important;
}

/* GF 管理画面タイトルは title="false" で非出力。念のため CSS でも非表示 */
.arc-ppf-sticky-modal__body :is(.gform_heading, .gform_wrapper .gform_title, .gform_wrapper .gform_description) {
  display: none !important;
}

/* iOS フォーカス時の自動ズーム防止（16px 未満だと Safari が拡大する） */
.arc-ppf-sticky-modal__body .ppf-quote-section .gform_wrapper input:not([type='radio']):not([type='checkbox']):not([type='submit']):not([type='button']):not([type='image']),
.arc-ppf-sticky-modal__body .ppf-quote-section .gform_wrapper textarea,
.arc-ppf-sticky-modal__body .ppf-quote-section .gform_wrapper select {
  font-size: 16px !important;
}

.arc-ppf-sticky-modal__loading {
  margin: 1rem 0;
  text-align: center;
  color: #424242;
}

/* 送信完了メッセージ — モーダル内でも黄背景で表示 */
.arc-ppf-sticky-modal__body .gform_confirmation_wrapper,
.arc-ppf-sticky-modal__body .gform_confirmation_message {
  display: block !important;
  color: var(--ppf-quote-text, #1a1a1a) !important;
  text-align: center;
  padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1rem, 3vw, 1.75rem);
}

.arc-ppf-sticky-modal__body .gform_confirmation_wrapper *,
.arc-ppf-sticky-modal__body .gform_confirmation_message * {
  color: inherit !important;
}
