/* ============================================================
 * sf-components.css — 全ページ共通UIコンポーネント
 *
 * Step 10-9 パス1b: event-page-header / split-slide-line / philosophy-kicker を
 * company / service(子) / philosophy / static / archive の5ファイルから集約。
 * 依存: sf-base.css（トークン）。全ページ enqueue + 各ページCSSの deps に追加する
 * 二段構えで、読込順は sf-base > sf-components > 各ページCSS に固定する。
 * ============================================================ */

/* ── Event Page Header（黒帯ヒーロー + 薄デカ英字） ── */
.event-page-header {
  position: relative;
  min-height: 420px;
  padding: 184px 0 72px;
  background: #fff;
  color: var(--c-navy);
  overflow: clip;
}
.event-page-header::before { content: none; }            /* service由来のSWELLリセット。無害 */

/* h1エリアは .container 非依存で自己完結（D-030: 既定1200px、body classで上書き可）。
 * 詳細度 (0,3,0) で各ページ .container（company 1440 / static 1120 等）に勝つ。 */
.event-page-header .event-page-header__inner.container {
  max-width: var(--sf-page-header-width, 1200px);
  margin: 0 auto;
  padding: 0 48px;
}
.event-page-header__inner {
  position: relative;
  z-index: 1;
}
.event-page-header__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--c-orange);
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .55s ease, transform .8s cubic-bezier(0.16, 1, 0.3, 1);
}
.event-page-header__eyebrow::before {
  content: "";
  width: 54px;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .7s cubic-bezier(0.16, 1, 0.3, 1) .12s;
}
.event-page-header__title {
  max-width: 820px;
}
.event-page-header__title-ja,
.event-page-header__title-en {
  display: block;
}
.event-page-header__title-ja {
  margin-bottom: 10px;
  font-size: clamp(36px, 5.4vw, 68px);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: 0.04em;
  color: var(--c-navy);
}
.event-page-header__title-en {
  font-family: "Oswald", sans-serif;
  font-size: clamp(20px, 3vw, 34px);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.16em;
  color: var(--c-orange);
}
.event-page-header__bg-en {
  position: absolute;
  right: -4%;
  bottom: -14%;
  font-family: "Oswald", sans-serif;
  font-weight: 700;
  font-size: clamp(160px, 22vw, 320px);
  line-height: 1;
  letter-spacing: 0.02em;
  color: var(--c-orange);
  opacity: 0.06;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  white-space: nowrap;
}

/* ── split-slide-line アニメーション ── */
.split-slide-line {
  display: block;
  width: fit-content;
  max-width: 100%;
  opacity: 0;
  filter: blur(10px);
  will-change: opacity, transform, filter;
}
.split-slide-line--ja {
  transform: translateY(84px) rotate(3deg);
  transition: opacity .32s ease, transform 1.02s cubic-bezier(0.16, 1, 0.3, 1), filter .56s ease;
}
.split-slide-line--en {
  transform: translateY(-62px) rotate(-2.5deg);
  transition: opacity .34s ease, transform 1.02s cubic-bezier(0.16, 1, 0.3, 1), filter .56s ease;
}

/* reveal トリガ（html.anim-ready は各ページJSが付与） */
html.anim-ready .event-page-header__eyebrow {
  opacity: 1;
  transform: translateY(0);
}
html.anim-ready .event-page-header__eyebrow::before {
  transform: scaleX(1);
}
html.anim-ready .split-slide-line {
  opacity: 1;
  filter: blur(0);
}
html.anim-ready .split-slide-line--ja {
  transform: translateY(0) rotate(0);
  transition-delay: .2s;
}
html.anim-ready .split-slide-line--en {
  transform: translateY(0) rotate(0);
  transition-delay: .38s;
}

/* ── philosophy-kicker（小ラベル） ── */
.philosophy-kicker {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  font-family: "Oswald", sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--c-orange);
  text-transform: uppercase;
}
.philosophy-kicker::before {
  content: "";
  width: 44px;
  height: 1px;
  background: currentColor;
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  .event-page-header__eyebrow,
  .split-slide-line {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }
  .event-page-header__eyebrow::before {
    transform: scaleX(1);
    transition: none;
  }
}

/* ── Responsive (SP) ── */
@media (max-width: 767px) {
  .event-page-header {
    min-height: 300px;
    padding: 146px 0 24px;
  }
  .event-page-header .event-page-header__inner.container {
    padding: 0 24px;
  }
  .event-page-header__title-en {
    letter-spacing: 0.1em;
  }
  .event-page-header__bg-en {
    font-size: 140px;
    right: -8%;
    bottom: -8%;
  }
  .philosophy-kicker {
    gap: 10px;
    margin-bottom: 16px;
    font-size: 12px;
    letter-spacing: 0.16em;
  }
  .philosophy-kicker::before {
    width: 34px;
  }
}

/* ============================================================
 * CF7 フォーム共通（CONTACT / ENTRY 共用トーン）
 *
 * CONTACT は sf-static-page.css、ENTRY(single-recruit) は sf-archive.css を
 * 読むが、両者とも sf-components.css に依存するため共通要素はここに集約する。
 * ページ固有のラッパー（.sf-form--contact / .sf-recruit-entry）は各ページCSSへ。
 * ============================================================ */
.sf-form__notice {
  margin: 0;
  padding: 48px 24px;
  text-align: center;
  color: var(--c-navy);
  font-size: 16px;
}

.sf-form .wpcf7 dl {
  margin: 0 0 22px;
}
.sf-form .wpcf7 dt {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 8px;
  color: var(--c-navy);
  font-weight: 700;
  letter-spacing: 0.04em;
}
.sf-form .wpcf7 dd {
  margin: 0;
}
.sf-form .sf-req,
.sf-form .sf-opt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 24px;
  padding: 2px 12px;
  margin-left: 0;
  margin-right: 8px;
  position: relative;
  top: -2px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1;
}
.sf-form .sf-req {
  color: #fff;
  background: var(--c-orange);
}
.sf-form .sf-opt {
  color: var(--c-navy);
  background: rgba(30, 47, 77, .1);
}

/* テキスト系入力（submit / acceptance / checkbox を除く） */
.sf-form .wpcf7-form-control:not(.wpcf7-submit):not(.wpcf7-acceptance):not(.wpcf7-checkbox) {
  width: 100%;
  padding: 13px 16px;
  border: 1px solid var(--c-border);
  border-radius: 8px;
  background: #fbfbfc;
  color: var(--c-navy);
  font-size: 16px;
  line-height: 1.6;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.sf-form textarea.wpcf7-form-control {
  min-height: 180px;
  resize: vertical;
}
.sf-form .wpcf7-form-control:focus {
  outline: none;
  border-color: var(--c-orange);
  box-shadow: 0 0 0 3px rgba(224, 85, 49, .15);
}

/* 姓・名・郵便番号など横並びの短い入力 */
.sf-form .sf-form__inline input.wpcf7-form-control {
  width: auto;
  max-width: 220px;
  margin-right: 10px;
}

.sf-form .sf-form__inline--address {
  display: contents;
}
.sf-form .sf-form__inline--address .wpcf7-form-control-wrap {
  min-width: 0;
}
.sf-form .sf-form__inline--address .sf-form__address-zip {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  min-width: 0;
}
.sf-form .sf-form__inline--address .sf-form__address-pref {
  display: block;
  min-width: 0;
}
.sf-form .sf-form__inline--address input.wpcf7-form-control,
.sf-form .sf-form__inline--address select.wpcf7-form-control {
  width: 100%;
  max-width: none;
  margin: 0;
}

/* CONTACT 住所欄: 郵便番号 / 都道府県を2カラム、住所を2行目の全幅にする */
.sf-form .sf-form__address,
.sf-form .wpcf7 dd:has(.sf-form__inline--address),
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 14px 16px !important;
  align-items: start;
}
.sf-form .sf-form__address > p {
  display: contents;
}
.sf-form .sf-form__address > br,
.sf-form .wpcf7 dd:has(.sf-form__inline--address) > br,
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) > br {
  display: none;
}
.sf-form .sf-form__address-zip,
.sf-form .sf-form__address-pref,
.sf-form .sf-form__address-detail,
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) .sf-form__inline,
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) .wpcf7-form-control-wrap[data-name="your-pref"],
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) .wpcf7-form-control-wrap[data-name="your-address"] {
  display: block;
  min-width: 0;
}
.sf-form .sf-form__address-zip {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}
.sf-form .sf-form__address-zip .wpcf7-form-control-wrap {
  display: block;
  min-width: 0;
}
.sf-form .sf-form__address-detail,
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) .wpcf7-form-control-wrap[data-name="your-address"] {
  grid-column: 1 / -1 !important;
}
.sf-form .sf-form__address-zip input.wpcf7-form-control,
.sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) .sf-form__inline input.wpcf7-form-control {
  width: calc(100% - 1.2em);
  max-width: none;
  margin: 0;
}

.sf-form select.wpcf7-form-control {
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--c-navy) 50%),
    linear-gradient(135deg, var(--c-navy) 50%, transparent 50%);
  background-position: calc(100% - 20px) 50%, calc(100% - 15px) 50%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 40px;
}

.sf-form .wpcf7-checkbox .wpcf7-list-item,
.sf-form .wpcf7-radio .wpcf7-list-item {
  display: inline-block;
  margin: 0 18px 8px 0;
}

.sf-form .wpcf7-acceptance {
  display: block;
  margin: 28px 0;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
}
.sf-form .wpcf7-acceptance a {
  color: var(--c-orange);
  font-weight: 700;
  text-decoration: underline;
}

.sf-form .sf-form__actions,
.sf-form .sf-formactions {
  display: grid;
  justify-items: center;
  gap: 8px;
  margin-top: 12px;
}

.sf-form .sf-form__actions > p,
.sf-form .sf-formactions > p {
  margin: 0;
}

.sf-form .sf-form__actions .wpcf7-acceptance,
.sf-form .sf-formactions .wpcf7-acceptance,
.sf-form .sf-form__turnstile,
.sf-form .sf-formturnstile,
.sf-form .sf-form__actions .wpcf7-submit,
.sf-form .sf-formactions .wpcf7-submit {
  margin: 0;
}

.sf-form .sf-form__turnstile,
.sf-form .sf-formturnstile {
  display: flex;
  justify-content: center;
  width: 100%;
}

.sf-form .sf-form__turnstile .cf-turnstile,
.sf-form .sf-form__turnstile .wpcf7-turnstile,
.sf-form .sf-form__turnstile .wpcf7-form-control-wrap[data-name="turnstile"],
.sf-form .sf-formturnstile .cf-turnstile,
.sf-form .sf-formturnstile .wpcf7-turnstile,
.sf-form .sf-formturnstile .wpcf7-form-control-wrap[data-name="turnstile"] {
  margin-inline: auto;
}

.sf-form .wpcf7-submit {
  display: block;
  width: 100%;
  max-width: 420px;
  margin: 8px auto 0;
  min-height: 56px;
  border: none;
  border-radius: 999px;
  background: var(--c-navy);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.08em;
  cursor: pointer;
  transition: background .25s ease, transform .25s ease;
}
.sf-form .wpcf7-submit:hover {
  background: var(--c-orange);
  transform: translateY(-2px);
}
.sf-form .wpcf7-submit:disabled {
  background: #ccc;
  cursor: not-allowed;
  transform: none;
}

.sf-form .wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  color: var(--c-orange);
  font-size: 13px;
}
.sf-form .wpcf7-response-output {
  margin: 24px 0 0;
  padding: 14px 18px;
  border-radius: 8px;
  font-size: 14px;
}

@media (max-width: 767px) {
  .sf-form .wpcf7 dt {
    flex-wrap: wrap;
  }
  .sf-form .sf-form__inline input.wpcf7-form-control {
    width: 100%;
    max-width: none;
    margin: 0 0 10px;
  }
  .sf-form .sf-form__inline--address input.wpcf7-form-control,
  .sf-form .sf-form__inline--address select.wpcf7-form-control {
    margin: 0;
  }
  .sf-form .sf-form__address,
  .sf-form .wpcf7 dd:has(.sf-form__inline--address),
  .sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) {
    grid-template-columns: minmax(0, 5.5fr) minmax(0, 4.5fr) !important;
    gap: 10px;
  }
  .sf-form .sf-form__address-zip input.wpcf7-form-control,
  .sf-form .wpcf7 dd:has(.wpcf7-form-control-wrap[data-name="your-zip"]) .sf-form__inline input.wpcf7-form-control {
    width: calc(100% - 1.2em);
    margin: 0;
  }
}
