/*
 * CRAFOVA LP CSS
 * v39 — CF7エラー表示制御を独自エラー（.crafova-live-error）に一本化
 * Loaded via lightning-child/functions.php (wp_enqueue_style)
 */

:root{
  --orange:#F97316;
  --orange-dark:#EA580C;
  --orange-soft:#FFF7ED;
  --navy:#0F172A;
  --text:#1E293B;
  --text-mute:#475569;
  --text-light:#94A3B8;
  --line:#E2E8F0;
  --header-height:68px;
}

[id]{ scroll-margin-top: calc(var(--header-height) + 24px); }
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:'Noto Sans JP',-apple-system,BlinkMacSystemFont,'Hiragino Kaku Gothic ProN','Meiryo',sans-serif;
  color:var(--text);
  line-height:1.7;
  background:#fff;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.container{
  width:min(100% - 80px, 1360px);
  margin-inline:auto;
  padding-inline:0;
}
@media (min-width:1440px){ .container{ width:min(100% - 120px, 1440px); } }

/* ===================== HEADER ===================== */
.site-header{ background:#fff; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:100; height:var(--header-height); }
.header-inner{ display:flex; align-items:center; gap:32px; height:100%; width:min(100% - 80px, 1360px); margin-inline:auto; }
@media (min-width:1440px){ .header-inner{ width:min(100% - 120px, 1440px); } }
.brand{ display:flex; align-items:center; gap:14px; flex-shrink:0; }
.brand-logo-link{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  line-height:1;
  transition:opacity .15s;
}
.brand-logo-link:hover{
  opacity:0.75;
}
.brand-logo-img{ height:36px; width:auto; display:block; }
.brand-tagline{ font-size:11.5px; color:var(--text-mute); border-left:1px solid var(--line); padding-left:12px; letter-spacing:0.02em; line-height:1.45; white-space:nowrap; }
.global-nav{ display:flex; align-items:center; gap:28px; margin-left:auto; }
.global-nav a{ font-size:14px; color:var(--navy); font-weight:500; position:relative; padding:6px 0; white-space:nowrap; }
.global-nav a:hover{ color:var(--orange); }
.global-nav a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:2px; background:var(--orange); transition:width .2s; }
.global-nav a:hover::after{ width:100%; }
.header-sublink{ display:inline-flex; align-items:center; gap:4px; font-size:12.5px; color:var(--text-mute); font-weight:500; padding:6px 10px; border:1px solid var(--line); border-radius:4px; transition:color .15s, border-color .15s, background .15s; white-space:nowrap; flex-shrink:0; letter-spacing:0.02em; }
.header-sublink:hover{ color:var(--orange); border-color:#FED7AA; background:var(--orange-soft); }
.header-cta{ display:inline-flex; align-items:center; gap:8px; background:var(--orange); color:#fff; font-size:14px; font-weight:700; padding:10px 20px; border-radius:6px; transition:background .15s; white-space:nowrap; flex-shrink:0; }
.header-cta:hover{ background:var(--orange-dark); }
.header-cta::after{ content:"›"; font-size:18px; line-height:1; }
.hamburger{ display:none; background:none; border:none; padding:0; cursor:pointer; width:28px; height:22px; flex-direction:column; justify-content:space-between; flex-shrink:0; }
.hamburger span{ display:block; width:100%; height:2.5px; background:var(--navy); transition:transform 0.3s ease, opacity 0.3s ease; border-radius:2px; }
.hamburger.is-open span:nth-child(1){ transform:translateY(9.75px) rotate(45deg); }
.hamburger.is-open span:nth-child(2){ opacity:0; }
.hamburger.is-open span:nth-child(3){ transform:translateY(-9.75px) rotate(-45deg); }
.mobile-nav{ display:none; position:absolute; top:var(--header-height); left:0; right:0; flex-direction:column; background:#fff; border-top:1px solid var(--line); padding:8px 0 16px; box-shadow:0 8px 24px rgba(15,23,42,0.08); z-index:99; }
.mobile-nav a{ padding:14px 24px; color:var(--navy); text-decoration:none; border-bottom:1px solid var(--line); font-size:14.5px; font-weight:500; transition:color .15s ease, background .15s ease; }
.mobile-nav a:hover{ color:var(--orange); background:var(--orange-soft); }
.mobile-nav a:last-child{ border-bottom:none; }
.mobile-nav .mobile-cta{ margin:16px 24px 8px; background:var(--orange); color:#fff; border-radius:6px; text-align:center; font-weight:700; border-bottom:none; padding:13px 16px; font-size:15px; }
.mobile-nav .mobile-cta:hover{ background:var(--orange-dark); color:#fff; }
.mobile-nav .mobile-sublink{ margin:0 24px 4px; padding:10px 12px; font-size:12.5px; color:var(--text-mute); font-weight:400; text-align:center; border-bottom:none; border:1px solid var(--line); border-radius:4px; background:#fff; }
.mobile-nav .mobile-sublink:hover{ color:var(--orange); background:var(--orange-soft); border-color:#FED7AA; }
.mobile-nav.is-open{ display:flex; }
@media (max-width:1180px){
  .header-inner{ width:min(100% - 48px, 1120px); gap:24px; }
  .global-nav{ display:none; }
  .header-sublink{ display:none; }
  .header-cta{ padding:9px 16px; font-size:13px; }
  .brand-tagline{ display:none; }
  .container{ width:min(100% - 56px, 1120px); }
  .hero-text{ width:min(50%, 620px); }
  .hero-headline{ font-size:clamp(32px, 3.2vw, 42px); }
  .hamburger{ display:flex; }
}

/* ===================== HERO ===================== */
.hero{ position:relative; overflow:hidden; background:#fff; min-height:clamp(600px, calc(100svh - var(--header-height)), 760px); }
.hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; object-position:68% center; }
@media (min-width:1440px){ .hero-bg img{ object-position:72% center; } }
@media (max-width:1023px){ .hero-bg img{ object-position:65% center; } }
.hero::after{ content:""; position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(90deg, #ffffff 0%, #ffffff 31%, rgba(255,255,255,0.96) 38%, rgba(255,255,255,0.76) 46%, rgba(255,255,255,0.28) 55%, rgba(255,255,255,0.00) 64%); }
.hero-inner{ position:relative; z-index:2; min-height:inherit; display:flex; align-items:center; padding:clamp(48px, 6vh, 80px) 0; }
.hero-text{ width:min(46%, 660px); max-width:660px; }
.hero-eyebrow{ display:inline-flex; align-items:center; gap:10px; font-size:13px; font-weight:700; color:var(--orange-dark); letter-spacing:0.03em; margin-bottom:clamp(14px, 2vh, 20px); line-height:1.5; }
.hero-eyebrow::before{ content:""; width:20px; height:2px; background:var(--orange); flex-shrink:0; }
.hero-headline{ font-size:clamp(34px, 3.1vw, 48px); font-weight:900; color:var(--navy); line-height:1.42; letter-spacing:0.01em; margin-bottom:clamp(18px, 2.5vh, 26px); padding-left:0; border-left:none; }
.hero-headline .accent{ color:var(--orange); }
.hero-sub{ font-size:14px; color:var(--text-mute); line-height:1.85; margin-bottom:clamp(20px, 3vh, 28px); }
.cta-row{ display:flex; gap:14px; margin-bottom:clamp(20px, 3vh, 30px); flex-wrap:wrap; }
.cta-primary,.cta-secondary{ display:inline-flex; align-items:center; justify-content:center; gap:10px; font-size:15px; font-weight:700; padding:15px 26px; border-radius:6px; transition:all .15s; white-space:nowrap; }
.cta-primary{ background:var(--orange); color:#fff; box-shadow:0 4px 14px rgba(249,115,22,.25); }
.cta-primary::after{ content:"›"; font-size:20px; line-height:1; }
.cta-primary:hover{ background:var(--orange-dark); transform:translateY(-1px); }
.cta-secondary{ background:transparent; color:var(--navy); border:1.5px solid var(--navy); }
.cta-secondary::after{ content:"›"; font-size:20px; line-height:1; }
.cta-secondary:hover{ background:var(--navy); color:#fff; }
.support-flow{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:clamp(14px, 2vh, 22px); }
.flow-chip{ display:inline-flex; align-items:center; padding:7px 13px; font-size:12.5px; font-weight:500; color:var(--navy); background:rgba(255,255,255,0.88); border:1px solid var(--line); border-radius:6px; transition:all .15s; }
.flow-chip:hover{ border-color:var(--orange); color:var(--orange); }
.meta-row{ display:flex; gap:20px; font-size:12px; color:var(--text-mute); flex-wrap:wrap; }
.meta-item{ display:flex; align-items:center; gap:6px; }
.meta-icon{ width:13px; height:13px; fill:none; stroke:currentColor; stroke-width:2; }

/* ===================== ABOUT LEAD ===================== */
.about-lead{ background:#fff; padding:56px 40px 64px; text-align:center; border-top:1px solid var(--line); }
.about-kicker{ font-family:'Bebas Neue',sans-serif; font-size:13px; letter-spacing:3px; color:var(--text-mute); margin-bottom:14px; display:flex; align-items:center; justify-content:center; gap:14px; }
.about-kicker::before,.about-kicker::after{ content:""; width:36px; height:1px; background:var(--line); }
.about-lead h2{ font-size:clamp(22px, 2vw, 28px); font-weight:700; color:var(--navy); position:relative; display:inline-block; }
.about-lead h2::after{ content:""; position:absolute; bottom:-12px; left:50%; transform:translateX(-50%); width:36px; height:3px; background:var(--orange); }
.about-lead h2 .accent{ color:var(--orange); }
.about-text{ margin:28px auto 0; max-width:720px; font-size:14.5px; color:var(--text-mute); line-height:1.9; text-align:center; }
@media (max-width:767px){ .about-text{ font-size:13.5px; text-align:left; } }

/* ===================== ISSUES SECTION ===================== */
.issues-section{ background:#F8FAFC; padding:clamp(64px, 9vh, 96px) 0; border-top:1px solid var(--line); }
.issues-inner{ text-align:center; }
.issues-kicker{ font-family:'Bebas Neue',sans-serif; font-size:13px; letter-spacing:3px; color:var(--text-mute); margin-bottom:14px; display:flex; align-items:center; justify-content:center; gap:14px; }
.issues-kicker::before,.issues-kicker::after{ content:""; width:36px; height:1px; background:var(--line); }
.issues-section h2{ font-size:clamp(24px, 2.4vw, 32px); font-weight:700; color:var(--navy); margin-bottom:14px; position:relative; display:inline-block; }
.issues-section h2::after{ content:""; position:absolute; bottom:-12px; left:50%; transform:translateX(-50%); width:36px; height:3px; background:var(--orange); }
.issues-lead{ font-size:15px; color:var(--text-mute); margin:32px auto 48px; max-width:720px; line-height:1.85; }
.issues-grid{ display:grid; grid-template-columns:repeat(2, 1fr); gap:24px; margin:0 auto 48px; max-width:960px; text-align:left; }
.issue-card{ background:#fff; border:1px solid var(--line); border-radius:8px; padding:28px 24px; transition:all .2s; display:flex; flex-direction:column; position:relative; }
.issue-card:hover{ border-color:var(--orange); transform:translateY(-2px); box-shadow:0 6px 18px rgba(15,23,42,0.06); }
.issue-card .issue-visual{ width:calc(100% + 48px); margin:-28px -24px 20px; aspect-ratio:4 / 3; background:#F8FAFC; overflow:hidden; border-radius:8px 8px 0 0; display:flex; align-items:center; justify-content:center; }
.issue-card .issue-visual img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .3s ease; }
.issue-card:hover .issue-visual img{ transform:scale(1.03); }
.issue-card h3{ font-size:15.5px; font-weight:700; color:var(--navy); line-height:1.55; margin-bottom:12px; }
.issue-card p{ font-size:13.5px; color:var(--text-mute); line-height:1.75; margin-bottom:18px; flex-grow:1; }
.issues-bottom{ text-align:center; }
.issues-bottom-text{ font-size:14.5px; color:var(--text); margin-bottom:20px; }
.issues-cta{ display:inline-flex; align-items:center; gap:10px; background:var(--orange); color:#fff; font-size:15px; font-weight:700; padding:15px 32px; border-radius:6px; box-shadow:0 4px 14px rgba(249,115,22,.25); transition:all .15s; }
.issues-cta::after{ content:"›"; font-size:20px; line-height:1; }
.issues-cta:hover{ background:var(--orange-dark); transform:translateY(-1px); }
@media (max-width:767px){
  .issues-section{ padding:56px 0; }
  .issues-grid{ grid-template-columns:1fr; gap:14px; margin-bottom:36px; }
  .issue-card{ padding:22px 20px; }
  .issue-card .issue-visual{ width:calc(100% + 40px); margin:-22px -20px 16px; aspect-ratio:16 / 10; }
  .issues-lead{ font-size:14px; margin:24px auto 32px; }
  .issues-cta{ width:100%; justify-content:center; padding:14px 20px; }
}

/* ===================== SERVICES SECTION ===================== */
.services-section{ background:#fff; padding:clamp(64px, 9vh, 96px) 0; border-top:1px solid var(--line); }
.services-inner{ text-align:center; }
.services-kicker{ font-family:'Bebas Neue',sans-serif; font-size:13px; letter-spacing:3px; color:var(--text-mute); margin-bottom:14px; display:flex; align-items:center; justify-content:center; gap:14px; }
.services-kicker::before,.services-kicker::after{ content:""; width:36px; height:1px; background:var(--line); }
.services-section h2{ font-size:clamp(24px, 2.4vw, 32px); font-weight:700; color:var(--navy); margin-bottom:14px; position:relative; display:inline-block; }
.services-section h2::after{ content:""; position:absolute; bottom:-12px; left:50%; transform:translateX(-50%); width:36px; height:3px; background:var(--orange); }
.services-lead{ font-size:15px; color:var(--text-mute); margin:32px auto 56px; max-width:760px; line-height:1.85; }
.services-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; margin-bottom:64px; text-align:left; }
.service-card{ background:#fff; border:1px solid var(--line); border-radius:8px; padding:32px 24px 28px; transition:all .2s; display:flex; flex-direction:column; position:relative; }
.service-card:hover{ border-color:var(--orange); transform:translateY(-2px); box-shadow:0 6px 18px rgba(15,23,42,0.06); }
.service-num{ font-family:'Bebas Neue',sans-serif; font-size:32px; letter-spacing:0.05em; color:var(--orange); line-height:1; margin-bottom:18px; display:flex; align-items:center; gap:12px; }
.service-num::after{ content:""; flex:1; height:1px; background:var(--line); }
.service-card h3{ font-size:17px; font-weight:700; color:var(--navy); line-height:1.5; margin-bottom:14px; letter-spacing:0.01em; }
.service-card p{ font-size:13.5px; color:var(--text-mute); line-height:1.8; margin-bottom:22px; flex-grow:1; }
.service-tags{ list-style:none; display:flex; flex-wrap:wrap; gap:6px; margin-top:auto; padding:0; }
.service-tags li{ font-size:11.5px; color:var(--orange-dark); background:var(--orange-soft); border:1px solid #FDE6D2; padding:5px 10px; border-radius:4px; line-height:1.4; font-weight:500; }
.domains-block{ background:#F8FAFC; border-radius:8px; padding:32px 36px; text-align:left; border:1px solid var(--line); }
.domains-title{ font-size:14px; font-weight:700; color:var(--navy); margin-bottom:18px; letter-spacing:0.02em; display:flex; align-items:center; gap:12px; }
.domains-title::before{ content:""; display:inline-block; width:18px; height:2px; background:var(--orange); }
.domains-list{ list-style:none; display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; padding:0; }
.domains-list li{ font-size:13px; color:var(--navy); background:#fff; border:1px solid var(--line); padding:7px 14px; border-radius:20px; font-weight:500; }
.domains-note{ font-size:12.5px; color:var(--text-mute); line-height:1.85; margin:0; padding-top:16px; border-top:1px dashed var(--line); }
.domains-note strong{ color:var(--navy); font-weight:600; margin-right:4px; }
@media (max-width:1180px){ .services-grid{ grid-template-columns:repeat(2, 1fr); } }
@media (max-width:767px){
  .services-section{ padding:56px 0; }
  .services-grid{ grid-template-columns:1fr; gap:14px; margin-bottom:48px; }
  .service-card{ padding:24px 20px 22px; }
  .service-num{ font-size:28px; margin-bottom:14px; }
  .services-lead{ font-size:14px; margin:24px auto 36px; }
  .domains-block{ padding:24px 20px; }
  .domains-title{ font-size:13.5px; }
  .domains-list li{ font-size:12px; padding:6px 12px; }
}

/* ===================== WHY CRAFOVA SECTION ===================== */
.why-section{ background:#F8FAFC; padding:clamp(64px, 9vh, 96px) 0; border-top:1px solid var(--line); }
.why-inner{ text-align:center; }
.why-kicker{ font-family:'Bebas Neue',sans-serif; font-size:13px; letter-spacing:3px; color:var(--text-mute); margin-bottom:14px; display:flex; align-items:center; justify-content:center; gap:14px; }
.why-kicker::before,.why-kicker::after{ content:""; width:36px; height:1px; background:var(--line); }
.why-section h2{ font-size:clamp(24px, 2.4vw, 32px); font-weight:700; color:var(--navy); margin-bottom:14px; position:relative; display:inline-block; }
.why-section h2::after{ content:""; position:absolute; bottom:-12px; left:50%; transform:translateX(-50%); width:36px; height:3px; background:var(--orange); }
.why-lead{ font-size:15px; color:var(--text-mute); margin:32px auto 56px; max-width:680px; line-height:1.85; }
.why-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; text-align:left; max-width:1200px; margin:0 auto; }
.why-card{ background:#fff; border:1px solid var(--line); border-radius:8px; padding:36px 28px 32px; transition:all .2s; display:flex; flex-direction:column; position:relative; }
.why-card:hover{ border-color:var(--orange); transform:translateY(-2px); box-shadow:0 6px 18px rgba(15,23,42,0.06); }
.why-num{ font-family:'Bebas Neue',sans-serif; font-size:38px; letter-spacing:0.05em; color:var(--orange); line-height:1; margin-bottom:22px; display:flex; align-items:center; gap:12px; }
.why-num::after{ content:""; flex:1; height:1px; background:var(--line); }
.why-card h3{ font-size:18px; font-weight:700; color:var(--navy); line-height:1.55; margin-bottom:16px; letter-spacing:0.01em; }
.why-card p{ font-size:13.5px; color:var(--text-mute); line-height:1.85; margin-bottom:22px; flex-grow:1; }
.why-stats{ list-style:none; margin:0; padding:18px 0 0; border-top:1px dashed var(--line); display:flex; flex-direction:column; gap:8px; }
.why-stats li{ font-size:12.5px; color:var(--text-mute); line-height:1.55; padding-left:18px; position:relative; }
.why-stats li::before{ content:""; position:absolute; left:0; top:8px; width:8px; height:2px; background:var(--orange); }
.why-stats strong{ color:var(--navy); font-weight:700; }
@media (max-width:1180px){ .why-grid{ grid-template-columns:repeat(2, 1fr); max-width:760px; } }
@media (max-width:767px){
  .why-section{ padding:56px 0; }
  .why-grid{ grid-template-columns:1fr; gap:16px; max-width:480px; }
  .why-card{ padding:28px 22px 24px; }
  .why-num{ font-size:32px; margin-bottom:18px; }
  .why-card h3{ font-size:17px; }
  .why-lead{ font-size:14px; margin:24px auto 36px; }
}

/* ===================== FLOW SECTION ===================== */
.flow-section{ background:#fff; padding:96px 0 104px; }
.flow-section .container{ width:min(100% - 80px, 1360px); margin:0 auto; }
.flow-section .section-head{ text-align:center; margin-bottom:56px; }
.flow-section .section-eyebrow{ font-family:'Bebas Neue', sans-serif; font-size:14px; letter-spacing:0.18em; color:var(--orange); margin-bottom:10px; }
.flow-section h2{ font-size:32px; line-height:1.4; color:var(--navy); font-weight:700; letter-spacing:0.02em; margin-bottom:16px; }
.flow-section .section-lead{ font-size:15px; color:var(--text-mute); line-height:1.8; max-width:680px; margin:0 auto; }
.flow-grid{ display:grid; grid-template-columns:repeat(5, 1fr); gap:20px; position:relative; }
.flow-card{ position:relative; background:#fff; border:1px solid var(--line); border-radius:10px; padding:28px 22px 24px; display:flex; flex-direction:column; transition:box-shadow .2s ease, transform .2s ease, border-color .2s ease; }
.flow-card:hover{ box-shadow:0 8px 24px rgba(15,23,42,0.08); transform:translateY(-2px); border-color:#FED7AA; }
.flow-num{ font-family:'Bebas Neue', sans-serif; font-size:22px; letter-spacing:0.1em; color:var(--orange); margin-bottom:14px; line-height:1; }
.flow-icon{ width:44px; height:44px; margin-bottom:18px; color:var(--orange); display:flex; align-items:center; justify-content:center; }
.flow-icon svg{ width:100%; height:100%; }
.flow-title{ font-size:17px; font-weight:700; color:var(--navy); line-height:1.5; margin-bottom:12px; letter-spacing:0.01em; }
.flow-body{ font-size:13.5px; color:var(--text); line-height:1.75; margin-bottom:16px; flex-grow:1; }
.flow-duration{ display:inline-flex; align-items:center; gap:6px; font-size:12px; color:var(--text-mute); background:#F8FAFC; border:1px solid var(--line); padding:6px 10px; border-radius:999px; align-self:flex-start; line-height:1.4; }
.flow-duration::before{ content:""; display:inline-block; width:4px; height:4px; border-radius:50%; background:var(--orange); }
.flow-card:not(:last-child)::after{ content:""; position:absolute; top:50%; right:-14px; width:8px; height:8px; border-top:2px solid #CBD5E1; border-right:2px solid #CBD5E1; transform:translateY(-50%) rotate(45deg); z-index:1; pointer-events:none; }
@media (max-width:1180px){
  .flow-section{ padding:80px 0 88px; }
  .flow-section .container{ width:min(100% - 64px, 960px); }
  .flow-section h2{ font-size:28px; }
  .flow-grid{ grid-template-columns:repeat(6, 1fr); gap:20px; }
  .flow-card:nth-child(1),.flow-card:nth-child(2),.flow-card:nth-child(3){ grid-column:span 2; }
  .flow-card:nth-child(4){ grid-column:2 / span 2; }
  .flow-card:nth-child(5){ grid-column:4 / span 2; }
  .flow-card:nth-child(3)::after{ display:none; }
}
@media (max-width:767px){
  .flow-section{ padding:64px 0 72px; }
  .flow-section .container{ width:min(100% - 40px, 600px); }
  .flow-section .section-head{ margin-bottom:40px; }
  .flow-section h2{ font-size:24px; }
  .flow-section .section-lead{ font-size:14px; text-align:left; }
  .flow-grid{ grid-template-columns:1fr; gap:16px; }
  .flow-card,.flow-card:nth-child(1),.flow-card:nth-child(2),.flow-card:nth-child(3),.flow-card:nth-child(4),.flow-card:nth-child(5){ grid-column:1 / -1 !important; padding:24px 22px 22px; }
  .flow-card:not(:last-child)::after{ top:auto; bottom:-12px; right:50%; left:50%; transform:translate(-50%, 0) rotate(135deg); }
  .flow-card:nth-child(3)::after{ display:block !important; }
  .flow-icon{ width:40px; height:40px; margin-bottom:14px; }
  .flow-num{ font-size:20px; }
  .flow-title{ font-size:16px; }
  .flow-body{ font-size:13.5px; }
}

/* ===================== COMPANY SECTION ===================== */
.company-section{
  background:#FAFBFC;
  padding:96px 0 104px;
  border-top:1px solid var(--line);
}
.company-section .company-inner{
  width:min(100% - 80px, 1180px);
  margin:0 auto;
}
.company-section .section-head{
  text-align:center;
  margin-bottom:56px;
}
.company-section .section-eyebrow{
  font-family:'Bebas Neue', sans-serif;
  font-size:14px;
  letter-spacing:0.18em;
  color:var(--orange);
  margin-bottom:10px;
}
.company-section h2{
  font-size:32px;
  line-height:1.4;
  color:var(--navy);
  font-weight:700;
  letter-spacing:0.02em;
  margin-bottom:16px;
}
.company-section .section-lead{
  font-size:15px;
  color:var(--text-mute);
  line-height:1.85;
  max-width:760px;
  margin:0 auto;
}

.company-grid{
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  gap:40px;
  align-items:start;
  margin-bottom:48px;
}

.greeting-title,
.company-info-title,
.company-info-heading{
  font-size:13px;
  font-weight:700;
  color:var(--navy);
  letter-spacing:0.1em;
  margin:0 0 20px;
  padding:0 0 10px;
  border-bottom:2px solid var(--orange);
  display:inline-block;
}

.company-greeting{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:36px 36px 32px;
}

.greeting-profile{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:22px;
  align-items:center;
  margin-bottom:24px;
  padding-bottom:24px;
  border-bottom:1px solid var(--line);
}
.greeting-photo{
  width:140px;
  aspect-ratio:4 / 5;
  min-height:175px;
  border-radius:10px;
  overflow:hidden;
  background:#F1F5F9;
  flex-shrink:0;
}
.greeting-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 20%;
  display:block;
}
.greeting-identity{ min-width:0; }
.greeting-name{
  font-size:22px;
  font-weight:700;
  color:var(--navy);
  letter-spacing:0.04em;
  line-height:1.3;
  margin-bottom:6px;
}
.greeting-role{
  font-size:13px;
  color:var(--text-mute);
  letter-spacing:0.02em;
  line-height:1.55;
}

.greeting-message{
  margin-bottom:28px;
}
.greeting-message p{
  font-size:14px;
  color:var(--text);
  line-height:1.95;
  margin:0 0 14px;
}
.greeting-message p:last-child{ margin-bottom:0; }

.greeting-career{
  padding-top:24px;
  border-top:1px solid var(--line);
}
.career-title{
  font-size:12.5px;
  font-weight:700;
  color:var(--navy);
  letter-spacing:0.1em;
  margin:0 0 16px;
  display:flex;
  align-items:center;
  gap:10px;
}
.career-title::before{
  content:"";
  width:16px;
  height:2px;
  background:var(--orange);
  flex-shrink:0;
}
.career-list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:0;
}
.career-item{
  display:grid;
  grid-template-columns:100px 1fr;
  gap:16px;
  align-items:start;
  padding:12px 0;
  border-bottom:1px dashed var(--line);
}
.career-item:last-child{ border-bottom:none; }
.career-period{
  font-family:'Bebas Neue', sans-serif;
  font-size:13.5px;
  letter-spacing:0.05em;
  color:var(--text-mute);
  line-height:1.4;
  padding-top:2px;
  white-space:nowrap;
}
.career-item-current .career-period{
  color:var(--orange-dark);
}
.career-body{ min-width:0; }
.career-org{
  font-size:14px;
  font-weight:700;
  color:var(--navy);
  line-height:1.45;
  margin-bottom:3px;
  letter-spacing:0.01em;
}
.career-desc{
  font-size:12.5px;
  color:var(--text-mute);
  line-height:1.7;
  margin:0;
}

.company-info{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:36px 32px 32px;
}
.company-table{
  margin:0;
  padding:0;
}
.company-row{
  display:grid;
  grid-template-columns:96px 1fr;
  gap:16px;
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.company-row:last-child{ border-bottom:none; }
.company-row:first-child{ padding-top:4px; }
.company-row dt{
  font-size:12px;
  font-weight:700;
  color:var(--navy);
  letter-spacing:0.06em;
  padding-top:2px;
  margin:0;
  line-height:1.5;
}
.company-row dd{
  margin:0;
  font-size:13.5px;
  line-height:1.75;
  color:var(--text);
}
.company-map-link{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-top:6px;
  font-size:12.5px;
  color:var(--orange);
  text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color .2s;
}
.company-map-link:hover{
  border-bottom-color:var(--orange);
  color:var(--orange);
}
.company-biz-list{
  list-style:none;
  padding:0;
  margin:0;
}
.company-biz-list li{
  position:relative;
  padding-left:14px;
  margin-bottom:4px;
  line-height:1.7;
  font-size:13px;
  color:var(--text);
}
.company-biz-list li::before{
  content:"";
  position:absolute;
  left:2px;
  top:9px;
  width:5px;
  height:5px;
  background:var(--orange);
  border-radius:50%;
}
.company-biz-list li:last-child{ margin-bottom:0; }

.company-cta{
  text-align:center;
  padding:40px 24px;
  background:#fff;
  border-radius:10px;
  border:1px solid var(--line);
}
.company-cta-text{
  font-size:14.5px;
  line-height:1.9;
  color:var(--text-mute);
  margin:0 0 24px;
}
.company-cta-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--orange);
  color:#fff;
  font-size:15px;
  font-weight:700;
  text-decoration:none;
  padding:15px 40px;
  border-radius:6px;
  box-shadow:0 4px 14px rgba(249,115,22,.25);
  transition:background .15s, transform .15s;
}
.company-cta-btn::after{ content:"›"; font-size:20px; line-height:1; }
.company-cta-btn:hover{
  background:var(--orange-dark);
  transform:translateY(-1px);
  color:#fff;
}

@media (max-width:1180px){
  .company-section{ padding:80px 0 88px; }
  .company-section .company-inner{ width:min(100% - 64px, 960px); }
  .company-section h2{ font-size:28px; }
  .company-grid{ gap:28px; }
  .company-greeting,.company-info{ padding:32px 28px 28px; }
}
@media (max-width:980px){
  .company-grid{ grid-template-columns:1fr; }
  .company-section .company-inner{ width:min(100% - 64px, 720px); }
}
@media (max-width:767px){
  .company-section{ padding:64px 0 72px; }
  .company-section .company-inner{ width:min(100% - 40px, 600px); }
  .company-section .section-head{ margin-bottom:40px; }
  .company-section h2{ font-size:24px; }
  .company-section .section-lead{ font-size:14px; text-align:left; line-height:1.8; }

  .company-greeting,.company-info{
    padding:26px 22px 24px;
    border-radius:10px;
  }
  .greeting-title,.company-info-title,.company-info-heading{ font-size:12px; }

  .greeting-profile{
    grid-template-columns:100px 1fr;
    gap:16px;
    margin-bottom:20px;
    padding-bottom:20px;
  }
  .greeting-photo{
    width:100px;
    min-height:125px;
  }
  .greeting-name{ font-size:19px; }
  .greeting-role{ font-size:12px; }
  .greeting-message p{ font-size:13.5px; line-height:1.9; }

  .career-item{
    grid-template-columns:86px 1fr;
    gap:12px;
    padding:11px 0;
  }
  .career-period{ font-size:12.5px; }
  .career-org{ font-size:13.5px; }
  .career-desc{ font-size:12px; line-height:1.65; }

  .company-row{
    grid-template-columns:1fr;
    gap:3px;
    padding:12px 0;
  }
  .company-row dt{
    font-size:10.5px;
    color:var(--orange);
    letter-spacing:0.12em;
  }
  .company-row dd{ font-size:13px; }
  .company-biz-list li{ font-size:12.5px; }

  .company-cta{ padding:32px 20px; }
  .company-cta-text{ font-size:13.5px; }
  .company-cta-btn{
    display:flex;
    justify-content:center;
    width:100%;
    padding:14px 24px;
  }
}

/* ===================== FAQ SECTION ===================== */
.faq-section{ background:#F8FAFC; padding:96px 0 104px; }
.faq-inner{ width:min(100% - 80px, 880px); margin:0 auto; }
.faq-section .section-head{ text-align:center; margin-bottom:48px; }
.faq-kicker{ font-family:'Bebas Neue', sans-serif; font-size:14px; letter-spacing:0.18em; color:var(--orange); margin-bottom:10px; }
.faq-section h2{ font-size:32px; line-height:1.4; color:var(--navy); font-weight:700; letter-spacing:0.02em; margin-bottom:16px; }
.faq-section .section-lead{ font-size:15px; color:var(--text-mute); line-height:1.8; max-width:680px; margin:0 auto; }
.faq-list{ display:flex; flex-direction:column; gap:12px; }
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:8px; overflow:hidden; transition:border-color .2s ease, box-shadow .2s ease; }
.faq-item[open]{ border-color:#FED7AA; box-shadow:0 4px 14px rgba(15,23,42,0.05); }
.faq-question{ display:flex; align-items:flex-start; gap:16px; padding:20px 24px; cursor:pointer; list-style:none; font-size:16px; font-weight:600; color:var(--navy); line-height:1.6; letter-spacing:0.01em; user-select:none; }
.faq-question::-webkit-details-marker{ display:none; }
.faq-question::marker{ display:none; content:""; }
.faq-q-label{ font-family:'Bebas Neue', sans-serif; font-size:18px; color:var(--orange); letter-spacing:0.06em; flex-shrink:0; line-height:1.45; min-width:24px; }
.faq-q-text{ flex-grow:1; }
.faq-toggle{ position:relative; width:20px; height:20px; flex-shrink:0; margin-top:2px; }
.faq-toggle::before,.faq-toggle::after{ content:""; position:absolute; background:var(--orange); border-radius:1px; transition:transform .25s ease, opacity .25s ease; }
.faq-toggle::before{ top:50%; left:0; width:100%; height:2px; transform:translateY(-50%); }
.faq-toggle::after{ top:0; left:50%; width:2px; height:100%; transform:translateX(-50%); }
.faq-item[open] .faq-toggle::after{ transform:translateX(-50%) rotate(90deg); opacity:0; }
.faq-answer{ padding:0 24px 22px 64px; font-size:14.5px; line-height:1.85; color:var(--text); }
.faq-answer p{ margin:0; }
.faq-item:not([open]) .faq-question:hover{ background:#FFF7ED; }
@media (max-width:1180px){
  .faq-section{ padding:80px 0 88px; }
  .faq-inner{ width:min(100% - 64px, 760px); }
  .faq-section h2{ font-size:28px; }
}
@media (max-width:767px){
  .faq-section{ padding:64px 0 72px; }
  .faq-inner{ width:min(100% - 40px, 600px); }
  .faq-section .section-head{ margin-bottom:32px; }
  .faq-section h2{ font-size:24px; }
  .faq-section .section-lead{ font-size:14px; text-align:left; }
  .faq-question{ padding:16px 18px; font-size:15px; gap:12px; }
  .faq-q-label{ font-size:16px; min-width:20px; }
  .faq-toggle{ width:18px; height:18px; }
  .faq-answer{ padding:0 18px 18px 50px; font-size:14px; line-height:1.8; }
}

/* ===================== TOOLS RESOURCE SECTION ===================== */
.tools-resource-section{ background:#fff; padding:48px 0 56px; border-top:1px solid var(--line); }
.tools-resource-inner{ width:min(100% - 80px, 1080px); margin:0 auto; }
.tools-resource-card{ display:flex; align-items:center; justify-content:space-between; gap:32px; padding:32px 36px; background:#FAFBFC; border:1px solid var(--line); border-radius:10px; }
.tools-resource-text{ flex:1; min-width:0; }
.tools-resource-eyebrow{ font-family:'Bebas Neue', sans-serif; font-size:12px; letter-spacing:0.18em; color:var(--text-mute); margin:0 0 8px; }
.tools-resource-title{ font-size:18px; font-weight:700; color:var(--navy); line-height:1.5; margin:0 0 8px; letter-spacing:0.01em; }
.tools-resource-body{ font-size:13.5px; color:var(--text-mute); line-height:1.8; margin:0; }
.tools-resource-btn{ display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--navy); font-size:13.5px; font-weight:600; text-decoration:none; padding:12px 22px; border:1px solid var(--navy); border-radius:6px; transition:background .15s, color .15s, transform .15s; white-space:nowrap; flex-shrink:0; }
.tools-resource-btn::after{ content:"›"; font-size:18px; line-height:1; }
.tools-resource-btn:hover{ background:var(--navy); color:#fff; transform:translateY(-1px); }
@media (max-width:980px){
  .tools-resource-card{ flex-direction:column; align-items:flex-start; gap:20px; padding:28px 28px; }
  .tools-resource-btn{ width:100%; justify-content:center; }
}
@media (max-width:767px){
  .tools-resource-section{ padding:40px 0 48px; }
  .tools-resource-inner{ width:min(100% - 40px, 600px); }
  .tools-resource-card{ padding:24px 22px; gap:16px; }
  .tools-resource-title{ font-size:16px; }
  .tools-resource-body{ font-size:13px; }
}

/* ===================== CONTACT SECTION ===================== */
.contact-section{ background:var(--navy); color:#fff; padding:clamp(72px, 10vh, 110px) 0; text-align:center; position:relative; }
.contact-section::before{ content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:60px; height:3px; background:var(--orange); }
.contact-inner{ max-width:720px; margin:0 auto; padding:0 20px; }
.contact-kicker{ font-family:'Bebas Neue',sans-serif; font-size:13px; letter-spacing:3px; color:#94A3B8; margin-bottom:18px; display:flex; align-items:center; justify-content:center; gap:14px; }
.contact-kicker::before,.contact-kicker::after{ content:""; width:36px; height:1px; background:rgba(255,255,255,0.15); }
.contact-section h2{ font-size:clamp(24px, 2.6vw, 34px); font-weight:700; color:#fff; margin-bottom:22px; letter-spacing:0.01em; }
.contact-lead{ font-size:15px; color:#CBD5E1; line-height:1.95; margin-bottom:38px; }
.contact-cta{ display:inline-flex; align-items:center; gap:10px; background:var(--orange); color:#fff; font-size:15.5px; font-weight:700; padding:17px 38px; border-radius:6px; box-shadow:0 6px 20px rgba(249,115,22,.35); transition:all .15s; text-decoration:none; }
.contact-cta::after{ content:"›"; font-size:20px; line-height:1; }
.contact-cta:hover{ background:var(--orange-dark); transform:translateY(-2px); box-shadow:0 10px 24px rgba(249,115,22,.45); }
@media (max-width:767px){
  .contact-section{ padding:64px 0; }
  .contact-lead{ font-size:14px; margin-bottom:28px; }
  .contact-cta{ width:100%; max-width:320px; justify-content:center; padding:15px 24px; }
}
.contact-inner.contact-inner-v2{ max-width:1080px; padding:0 24px; text-align:left; }
.contact-grid{ display:grid; grid-template-columns:0.95fr 1.1fr; gap:48px; align-items:start; }
.contact-left{ padding-top:4px; }
.contact-left .contact-kicker{ justify-content:flex-start; }
.contact-left .contact-kicker::before,
.contact-left .contact-kicker::after{ display:none; }
.contact-left h2{ text-align:left; margin-bottom:22px; }
.contact-left .contact-lead{ text-align:left; margin-bottom:20px; }
.contact-supplement{ font-size:13.5px; color:#94A3B8; line-height:1.85; margin:0 0 28px; padding:14px 16px; background:rgba(255,255,255,0.04); border-left:2px solid rgba(249,115,22,0.45); border-radius:2px; }

/* ===================== CONTACT FORM (CF7) ===================== */
.contact-form-card{
  background:#fff;
  color:var(--text);
  border-radius:10px;
  padding:32px 30px;
  box-shadow:0 12px 40px rgba(0,0,0,0.25);
}
.contact-form-card h3{
  font-size:16px;
  font-weight:700;
  color:var(--text);
  margin:0 0 18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
  letter-spacing:0.02em;
}
.contact-form-intro{
  margin:0 0 22px;
  font-size:13.5px;
  color:var(--text-mute);
  line-height:1.7;
}
.contact-form-card .wpcf7,
.contact-form-card .wpcf7-form,
.contact-form-card .wpcf7-form > p{ margin:0; padding:0; }
.contact-form-card .form-row{ margin:0 0 16px 0; padding:0; }
.contact-form-card .form-label{
  display:block;
  font-size:13px;
  font-weight:600;
  color:var(--text);
  margin:0 0 4px 0;
  padding:0;
  line-height:1.4;
  letter-spacing:0.02em;
}
.contact-form-card .form-label .required-mark{
  color:#DC2626;
  font-weight:700;
  font-size:14px;
  margin-left:3px;
  line-height:1;
  display:inline;
  background:transparent;
  vertical-align:middle;
}
.contact-form-card .wpcf7-form-control-wrap{ display:block; width:100%; margin:0; padding:0; }
.contact-form-card input[type="text"],
.contact-form-card input[type="email"],
.contact-form-card input[type="tel"],
.contact-form-card textarea{
  display:block;
  width:100%;
  margin:0;
  font-family:inherit;
  font-size:14px;
  color:var(--text);
  background:#F8FAFC;
  border:1px solid var(--line);
  border-radius:6px;
  padding:11px 13px;
  line-height:1.5;
  box-sizing:border-box;
  transition:border-color .15s, background .15s, box-shadow .15s;
}
.contact-form-card textarea{ resize:vertical; min-height:120px; }
.contact-form-card input[type="text"]:focus,
.contact-form-card input[type="email"]:focus,
.contact-form-card input[type="tel"]:focus,
.contact-form-card textarea:focus{
  outline:none;
  background:#fff;
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(249,115,22,0.12);
}
.contact-form-card input::placeholder,
.contact-form-card textarea::placeholder{ color:#94A3B8; }

.form-consent{
  margin:18px 0 22px;
  padding:14px;
  background:#F8FAFC;
  border:1px solid var(--line);
  border-radius:6px;
}
.form-consent label{ display:flex; align-items:flex-start; gap:10px; cursor:pointer; font-size:13px; line-height:1.75; color:var(--text); margin:0; }
.form-consent input[type="checkbox"]{ margin-top:3px; flex-shrink:0; width:16px; height:16px; accent-color:var(--orange); cursor:pointer; }
.form-consent a{ color:var(--orange); text-decoration:underline; text-underline-offset:2px; }
.form-consent a:hover{ color:var(--orange-dark); }
.form-consent .wpcf7-list-item{ margin:0; }
.form-consent .wpcf7-list-item-label{ font-size:13px; line-height:1.75; }
.contact-form-submit{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  background:var(--orange);
  color:#fff;
  font-size:15px;
  font-weight:700;
  font-family:inherit;
  padding:15px 24px;
  border:none;
  border-radius:6px;
  cursor:pointer;
  box-shadow:0 6px 20px rgba(249,115,22,.30);
  transition:background .15s, transform .15s, box-shadow .15s;
  letter-spacing:0.02em;
}
.contact-form-submit::after{ content:"›"; font-size:18px; line-height:1; }
.contact-form-submit:hover{ background:var(--orange-dark); transform:translateY(-1px); box-shadow:0 10px 24px rgba(249,115,22,.40); }

@media (max-width:980px){
  .contact-grid{ grid-template-columns:1fr; gap:36px; }
  .contact-inner.contact-inner-v2{ max-width:680px; }
}
@media (max-width:767px){
  .contact-inner.contact-inner-v2{ padding:0 20px; }
  .contact-grid{ gap:28px; }
  .contact-form-card{ padding:26px 22px; }
  .contact-form-card h3{ font-size:15px; margin-bottom:16px; }
  .contact-form-card .form-row{ margin-bottom:14px; }
  .contact-form-card input[type="text"],
  .contact-form-card input[type="email"],
  .contact-form-card input[type="tel"],
  .contact-form-card textarea{ font-size:16px; }
  .contact-supplement{ font-size:13px; }
  .contact-form-intro{ font-size:13px; }
}

/* ===================== SITE FOOTER ===================== */
.site-footer{ background:var(--navy); border-top:1px solid rgba(255,255,255,0.08); padding:40px 0 24px; color:rgba(255,255,255,0.55); font-size:12.5px; line-height:1.7; letter-spacing:0.02em; }
.footer-inner{ width:min(100% - 80px, 1360px); margin:0 auto; display:flex; flex-direction:column; align-items:center; gap:18px; }
.footer-nav{ display:flex; flex-wrap:wrap; gap:10px 22px; justify-content:center; width:100%; }
.footer-nav a{ color:rgba(255,255,255,0.65); text-decoration:none; font-size:13px; white-space:nowrap; transition:color .15s ease; }
.footer-nav a:hover{ color:var(--orange); }
.footer-company-block{ display:flex; flex-direction:column; align-items:center; gap:6px; padding:20px 0; border-top:1px solid rgba(255,255,255,0.08); width:100%; text-align:center; }
.footer-company-name{ font-size:14px; font-weight:600; color:rgba(255,255,255,0.8); margin:0; }
.footer-company-tag{ font-size:12px; color:rgba(255,255,255,0.45); margin:0; }
.footer-company-addr{ font-size:12.5px; color:rgba(255,255,255,0.55); margin:0; }
.footer-bottom{ display:flex; justify-content:center; align-items:center; gap:6px 14px; flex-wrap:wrap; font-size:12px; color:rgba(255,255,255,0.45); border-top:1px solid rgba(255,255,255,0.08); padding-top:16px; width:100%; text-align:center; }
.footer-copyright{ color:rgba(255,255,255,0.45); }
@media (max-width:1180px){ .footer-inner{ width:min(100% - 64px, 960px); } }
@media (max-width:767px){
  .site-footer{ padding:32px 0 20px; }
  .footer-inner{ width:min(100% - 40px, 600px); gap:14px; }
  .footer-nav{ gap:8px 14px; }
  .footer-nav a{ font-size:12px; }
  .footer-company-block{ padding:16px 0; gap:4px; }
  .footer-company-name{ font-size:13px; }
  .footer-bottom{ gap:4px 12px; padding-top:12px; }
}

/* ===================== スマホ（767px以下）ヘッダー ===================== */
@media (max-width:767px){
  :root{ --header-height:64px; }
  .site-header{ height:var(--header-height); }
  .header-inner{ width:calc(100% - 32px); gap:16px; }
  .brand-logo-img{ height:30px; }
  .brand-tagline, .global-nav{ display:none; }
  .header-sublink{ display:none; }
  .header-cta{ margin-left:auto; font-size:12px; padding:8px 12px; }
  .hamburger{ width:26px; height:20px; }
  .hamburger.is-open span:nth-child(1){ transform:translateY(8.75px) rotate(45deg); }
  .hamburger.is-open span:nth-child(3){ transform:translateY(-8.75px) rotate(-45deg); }
  .mobile-nav a{ padding:13px 20px; font-size:14px; }
  .mobile-nav .mobile-cta{ margin:14px 20px 8px; padding:12px 16px; font-size:14.5px; }
  .mobile-nav .mobile-sublink{ margin:0 20px 4px; padding:9px 12px; font-size:12px; }
  .hero{ min-height:auto; }
  .hero-bg img{ object-position:72% center; opacity:0.28; }
  .hero::after{ background:linear-gradient(90deg, rgba(255,255,255,0.98) 0%, rgba(255,255,255,0.94) 100%); }
  .hero-inner{ min-height:auto; padding:56px 0 48px; }
  .container{ width:calc(100% - 32px); }
  .hero-text{ width:100%; max-width:none; }
  .hero-eyebrow{ font-size:12px; line-height:1.6; }
  .hero-headline{ font-size:clamp(28px, 8vw, 36px); line-height:1.45; }
  .hero-sub{ font-size:13.5px; }
  .cta-row{ flex-direction:column; gap:10px; }
  .cta-primary, .cta-secondary{ width:100%; padding:14px 20px; }
  .support-flow{ gap:8px; }
  .flow-chip{ font-size:12px; padding:7px 11px; }
  .meta-row{ gap:12px; font-size:12px; }
  .about-lead{ padding:44px 24px 56px; }
}

/* ===================== CF7 エラー表示制御（独自エラー一本化 v39） ===================== */

/* CF7標準エラーメッセージは完全非表示 */
.contact-form-card .wpcf7-not-valid-tip {
  display: none !important;
}

/* invalid/unaccepted/spam/failed時のフォーム下部メッセージは非表示 */
.contact-form-card .wpcf7-response-output,
.contact-form-card form.invalid .wpcf7-response-output,
.contact-form-card form.unaccepted .wpcf7-response-output,
.contact-form-card form.spam .wpcf7-response-output,
.contact-form-card form.failed .wpcf7-response-output {
  display: none !important;
}

/* 送信成功時のメッセージのみ表示 */
.contact-form-card form.sent .wpcf7-response-output {
  display: block !important;
  margin: 16px 0 0 !important;
  padding: 12px 14px !important;
  font-size: 13px;
  line-height: 1.7;
  border-radius: 6px;
  border: 1px solid #16A34A;
  background: #F0FDF4;
  color: #15803D;
}

/* エラー時の入力欄スタイル */
.contact-form-card input.wpcf7-not-valid,
.contact-form-card textarea.wpcf7-not-valid,
.contact-form-card select.wpcf7-not-valid {
  border-color: #DC2626 !important;
  background: #FEF2F2 !important;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.08) !important;
}

/* 独自エラーメッセージ */
.crafova-live-error {
  display: block;
  margin: 4px 0 0 0;
  padding: 0;
  font-size: 12px;
  color: #DC2626;
  line-height: 1.4;
  font-weight: 500;
  background: transparent;
  border: none;
}

/* form-consent（同意チェックボックス）内のエラー表示位置調整 */
.form-consent + .crafova-live-error,
.wpcf7-form-control-wrap + .crafova-live-error {
  margin-top: 8px;
}

/* フォーム下部の補足テキスト */
.form-footnote {
  font-size: 12px;
  color: var(--text-mute);
  text-align: center;
  margin: 14px 0 0;
  line-height: 1.7;
}