/* ========================================
   WeLive 共通CSS - 全ページで使用
======================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --blue:#4A90D9;--blue-light:#72AEDE;--blue-pale:#EBF4FC;
  --teal:#3DBFAA;--teal-light:#6DD4C3;--teal-pale:#E8F8F5;
  --gold:#F5C842;--gold-light:#F9D96A;--gold-pale:#FEF8E1;
  --warm-white:#FAFAF7;--cream:#F5F3ED;
  --text-dark:#2D2D2D;--text-mid:#5A5A5A;--text-light:#8A8A8A;
  --font-jp:'Zen Maru Gothic',sans-serif;--font-en:'Outfit',sans-serif;
  --shadow-card:0 4px 24px rgba(0,0,0,0.07);
  --shadow-soft:0 8px 40px rgba(74,144,217,0.12);
}
html{scroll-behavior:smooth}
body{background:var(--warm-white);color:var(--text-dark);font-family:var(--font-jp);overflow-x:hidden;line-height:1.8;margin:0!important;padding:0!important}

/* NAV - WeLive organic glass header */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:99999;
  height:82px;
  padding:0 5%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(250,250,247,.88);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(74,144,217,.12);
  box-shadow:0 10px 36px rgba(74,144,217,.07);
}
.nav::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 12% 50%, rgba(74,144,217,.10), transparent 30%),
    radial-gradient(circle at 88% 50%, rgba(61,191,170,.09), transparent 28%),
    linear-gradient(90deg, rgba(245,200,66,.10), transparent 35%, rgba(74,144,217,.08));
  pointer-events:none;
}
.nav-logo{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  text-decoration:none;
}
.nav-logo-img{
  height:52px !important;   /* 全ページ統一：各ページの個別上書きを打ち消す */
  width:auto;
  display:block;
  object-fit:contain;
}
.nav-links{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  gap:1.45rem;
}
.nav-links a,
.nav-group-label{
  color:var(--text-mid);
  text-decoration:none;
  font-size:.9rem;
  font-weight:700;
  letter-spacing:.02em;
  cursor:pointer;
  transition:color .25s ease, transform .25s ease;
  white-space:nowrap;
}
.nav-links a:hover,
.nav-group-label:hover{
  color:var(--blue);
}
.nav-group{
  position:relative;
  padding:29px 0;
}
.nav-group-label::after{
  content:'⌄';
  margin-left:.35rem;
  color:var(--teal);
  font-size:.8rem;
}
.nav-dropdown{
  position:absolute;
  top:74px;
  left:50%;
  transform:translateX(-50%) translateY(10px);
  min-width:230px;
  padding:.75rem;
  background:rgba(255,255,255,.96);
  border:1px solid rgba(74,144,217,.13);
  border-radius:22px;
  box-shadow:0 20px 55px rgba(74,144,217,.16);
  opacity:0;
  visibility:hidden;
  transition:opacity .22s ease, transform .22s ease, visibility .22s ease;
}
.nav-group:hover .nav-dropdown{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
}
.nav-dropdown a{
  display:block;
  padding:.72rem .9rem;
  border-radius:14px;
  color:var(--text-mid);
}
.nav-dropdown a:hover{
  color:var(--blue);
  background:linear-gradient(135deg,var(--blue-pale),var(--teal-pale));
}
.nav-privacy{
  color:var(--text-light)!important;
}
.nav-cta{
  background:linear-gradient(135deg,var(--blue),var(--teal));
  color:#fff!important;
  padding:.72rem 1.45rem;
  border-radius:999px;
  box-shadow:0 8px 24px rgba(74,144,217,.30);
}
.nav-cta:hover{
  transform:translateY(-2px);
  color:#fff!important;
}

/* 共通セクション */
.section{padding:6rem 5%}
.section-inner{max-width:1100px;margin:0 auto}
.section-label{font-family:var(--font-en);font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:.8rem}
.section-title{font-size:clamp(1.8rem,3.5vw,3rem);font-weight:700;line-height:1.25;letter-spacing:-.02em;margin-bottom:1.2rem}
.section-desc{font-size:1rem;color:var(--text-mid);line-height:1.85;font-weight:400}

/* ボタン共通 */
.btn-main{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,var(--blue),var(--teal));color:#fff;padding:.85rem 2rem;border-radius:50px;font-size:.95rem;font-weight:600;text-decoration:none;font-family:var(--font-en);box-shadow:0 6px 28px rgba(74,144,217,.4);transition:transform .25s,box-shadow .25s}
.btn-main:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(74,144,217,.5)}
.btn-sub{display:inline-flex;align-items:center;gap:.5rem;border:1.5px solid rgba(74,144,217,.35);color:var(--blue);padding:.85rem 1.8rem;border-radius:50px;font-size:.95rem;font-weight:600;text-decoration:none;font-family:var(--font-en);transition:all .25s}
.btn-sub:hover{border-color:var(--blue);background:var(--blue-pale)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* FOOTER */
footer{background:#1E2A3A;color:rgba(255,255,255,.75);padding:4rem 5% 2.5rem}
.footer-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.footer-brand{font-family:var(--font-en);font-size:1.2rem;font-weight:600;color:#fff;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}
.footer-logo-img{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.8}
.footer-tagline{font-size:.87rem;color:rgba(255,255,255,.5);line-height:1.8;margin-bottom:1.2rem}
.footer-info{font-size:.78rem;color:rgba(255,255,255,.35);line-height:1.9}
.footer-info a{color:rgba(255,255,255,.45);text-decoration:none}
.f-col-title{font-size:.65rem;font-family:var(--font-en);font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem}
.f-links{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.f-links a{color:rgba(255,255,255,.55);text-decoration:none;font-size:.87rem;transition:color .2s}
.f-links a:hover{color:var(--teal-light)}
.footer-bottom{max-width:1100px;margin:0 auto;border-top:1px solid rgba(255,255,255,.08);padding-top:1.8rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.3);font-family:var(--font-en)}
.footer-legal{display:flex;gap:1.8rem}
.footer-legal a{color:rgba(255,255,255,.3);font-size:.75rem;text-decoration:none;font-family:var(--font-en);transition:color .2s}
.footer-legal a:hover{color:var(--teal-light)}

/* BLOB ANIMATIONS */
@keyframes blobF{0%,100%{border-radius:60% 40% 55% 45%/45% 60% 40% 55%}50%{border-radius:45% 55% 40% 60%/60% 40% 55%}}
@keyframes blobF2{0%,100%{border-radius:45% 55% 40% 60%/60% 40% 55% 45%}50%{border-radius:60% 40% 55% 45%/45% 60% 40% 55%}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* PAGE HERO 共通 */
.page-hero{padding:9rem 5% 5rem;background:linear-gradient(155deg,#fff 0%,var(--blue-pale) 50%,var(--teal-pale) 100%);position:relative;overflow:hidden}
.page-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--text-light);margin-bottom:1.5rem;font-family:var(--font-en)}
.breadcrumb a{color:var(--blue);text-decoration:none}
.page-label{font-family:var(--font-en);font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:.8rem}
.page-title{font-size:clamp(2.2rem,4vw,3.5rem);font-weight:700;line-height:1.2;letter-spacing:-.02em;margin-bottom:1rem}
.page-subtitle{font-size:1.05rem;color:var(--text-mid);line-height:1.8}

@media(max-width:980px){
  .nav{height:auto;min-height:76px;padding:14px 5%;align-items:flex-start}
  .nav-logo-img{height:44px !important}
  .nav-links{gap:.75rem;flex-wrap:wrap;justify-content:flex-end}
  .nav-group{padding:0}
  .nav-links a,.nav-group-label{font-size:.78rem}
  .nav-cta{padding:.48rem .9rem}
}
@media(max-width:768px){
  .nav-links{display:none}
  .footer-inner{grid-template-columns:1fr 1fr}
}

.reveal {
  opacity: 1 !important;
  transform: none !important;
}

.nav-links {
  display: flex !important;
}

.nav-group:hover .nav-dropdown {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
  transform: translateX(-50%) translateY(0) !important;
}

.nav-dropdown {
  pointer-events: auto !important;
}

.nav {
  transition:
    opacity 0.75s ease,
    transform 0.75s ease,
    background 0.4s ease,
    box-shadow 0.4s ease;
}

.nav.nav-hidden {
  opacity: 0;
  transform: translateY(-100%);
  pointer-events: none;
}

.nav.nav-visible {
  opacity: 1;
  transform: translateY(0);
}


.nav {
  transition:
    opacity .75s ease,
    transform .75s ease,
    background .4s ease,
    box-shadow .4s ease;
}

.nav.nav-hidden {
  opacity: 0;
  transform: translateY(-100%);
  pointer-events: none;
}

.nav.nav-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ========================================
   CONTACT FORM (WeConnect AI / Contact Form 7)
======================================== */
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
.form-group{margin-bottom:24px}

/* ラベル + 必須/任意バッジ */
.form-group>label{
  display:flex;
  align-items:center;
  gap:9px;
  margin-bottom:10px;
  color:var(--text-dark);
  font-weight:700;
  font-size:.95rem;
}
.form-group>label span{
  padding:3px 9px;
  border-radius:999px;
  background:var(--blue-pale);
  color:var(--blue);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.04em;
  line-height:1.5;
}
.form-group>label .optional{
  background:var(--cream);
  color:var(--text-light);
}

/* 入力欄（CF7 + 汎用） */
.wpcf7-form-control-wrap{display:block;width:100%}
.wpcf7-text,.wpcf7-tel,.wpcf7-email,.wpcf7-textarea,
.form-control{
  width:100%;
  font-family:var(--font-jp);
  font-size:1rem;
  color:var(--text-dark);
  padding:14px 16px;
  background:#FCFBF8;
  border:1.5px solid rgba(74,144,217,.16);
  border-radius:16px;
  outline:none;
  transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
.form-control::placeholder{color:#B9BEC6}
.form-control:hover{border-color:rgba(74,144,217,.32)}
.form-control:focus{
  border-color:var(--blue);
  background:#fff;
  box-shadow:0 0 0 4px rgba(74,144,217,.14);
}
textarea.form-control{min-height:160px;resize:vertical;line-height:1.8}

/* 目的選択：ラジオをピル型セレクターに */
.purpose-selector{
  display:inline-flex;
  gap:6px;
  flex-wrap:wrap;
  padding:6px;
  border-radius:18px;
  background:var(--cream);
  border:1px solid rgba(74,144,217,.10);
}
.purpose-selector .wpcf7-list-item{margin:0}
.purpose-selector .wpcf7-list-item label{
  position:relative;
  display:flex;
  align-items:center;
  margin:0;
  padding:11px 22px;
  border-radius:13px;
  cursor:pointer;
  font-weight:700;
  font-size:.92rem;
  color:var(--text-mid);
  transition:color .2s ease,background .25s ease,box-shadow .25s ease;
}
.purpose-selector input[type=radio]{position:absolute;opacity:0;pointer-events:none}
.purpose-selector .wpcf7-list-item-label::before{
  content:'';
  display:inline-block;
  width:9px;height:9px;
  margin-right:8px;
  border-radius:50%;
  border:2px solid #C4C9D1;
  transition:.2s ease;
}
.purpose-selector .wpcf7-list-item label:hover{color:var(--text-dark)}
.purpose-selector .wpcf7-list-item label:has(input:checked){
  background:#fff;
  color:var(--blue);
  box-shadow:0 6px 18px rgba(74,144,217,.22),0 1px 2px rgba(0,0,0,.04);
}
.purpose-selector .wpcf7-list-item label:has(input:checked) .wpcf7-list-item-label::before{
  border-color:var(--blue);
  background:radial-gradient(circle at center,var(--blue) 0 42%,#fff 46%);
}

/* 個人情報ボックス */
.privacy-box{
  margin:32px 0 4px;
  padding:26px 28px;
  max-height:264px;
  overflow-y:auto;
  background:linear-gradient(180deg,#FBFAF6,var(--cream));
  border:1px solid rgba(74,144,217,.12);
  border-radius:20px;
  color:var(--text-mid);
  font-size:.875rem;
  line-height:1.95;
}
.privacy-box h4{
  margin:18px 0 8px;
  color:var(--text-dark);
  font-size:.92rem;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:8px;
}
.privacy-box h4:first-child{margin-top:0}
.privacy-box h4::before{
  content:'';
  width:6px;height:6px;
  border-radius:50%;
  background:var(--teal);
}
.privacy-box p{margin:0 0 4px}
.privacy-box::-webkit-scrollbar{width:8px}
.privacy-box::-webkit-scrollbar-thumb{
  background:#D9D5CB;
  border-radius:99px;
  border:2px solid var(--cream);
}
.privacy-box::-webkit-scrollbar-track{background:transparent}

/* 同意チェックボックス */
.privacy-check{
  margin:24px 0 28px;
  display:flex;
  justify-content:center;
}
.privacy-check .wpcf7-list-item{margin:0}
.privacy-check label{
  display:inline-flex;
  align-items:center;
  gap:12px;
  cursor:pointer;
  font-weight:700;
  font-size:.95rem;
  color:var(--text-dark);
}
.privacy-check input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:22px;height:22px;
  border:1.5px solid #C7CDD5;
  border-radius:8px;
  background:#fff;
  display:grid;
  place-content:center;
  cursor:pointer;
  flex:0 0 auto;
  transition:.2s ease;
}
.privacy-check input[type=checkbox]::after{
  content:'';
  width:11px;height:11px;
  border-radius:4px;
  transform:scale(0);
  transition:.18s ease;
  background:linear-gradient(135deg,var(--blue),var(--teal));
}
.privacy-check input[type=checkbox]:checked{border-color:var(--blue)}
.privacy-check input[type=checkbox]:checked::after{transform:scale(1)}

/* 送信ボタン */
.submit-btn{
  width:100%;
  border:none;
  cursor:pointer;
  font-family:var(--font-en);
  font-weight:700;
  font-size:1rem;
  letter-spacing:.04em;
  color:#fff;
  padding:18px 24px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  box-shadow:0 6px 28px rgba(74,144,217,.4);
  transition:transform .25s ease,box-shadow .25s ease;
}
.submit-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 36px rgba(74,144,217,.5);
}
.submit-btn:active{transform:translateY(0)}

/* CF7 バリデーション表示 */
.wpcf7-not-valid-tip{
  color:#E2603C;
  font-size:.78rem;
  margin-top:6px;
  font-weight:600;
}
.wpcf7-not-valid{
  border-color:#E9A593!important;
  box-shadow:0 0 0 4px rgba(226,96,60,.1)!important;
}
.wpcf7 form .wpcf7-response-output{
  margin:18px 0 0;
  border-radius:14px;
  border-width:1px;
  padding:14px 16px;
  font-size:.9rem;
}

@media(max-width:620px){
  .form-row{grid-template-columns:1fr;gap:0}
}
