/* =====================================================
   SUICH | contact.css
   ─────────────────────────────────────────────────
   【用途】お問い合わせページ（contact.html）専用のスタイル
   　・相談方法タブ（フォーム・電話・LINE）
   　・お問い合わせフォームのスタイル
   　・入力項目・ボタン・送信後メッセージ
===================================================== */
/* =====================================================
   SUICH | contact.css
   ページ固有スタイル
===================================================== */

/* ── HEADER ── */
  /* ━━━ HEADER & MEGA MENU ━━━ */
}

  /* ── HERO ── */
  
  .hero-bg{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 70% 80% at 80% 50%,rgba(61,122,82,0.15) 0%,transparent 65%),radial-gradient(ellipse 40% 60% at 5% 90%,rgba(45,90,61,0.2) 0%,transparent 55%);}
  .hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--on-dark-ghost) 1px,transparent 1px),linear-gradient(90deg,var(--on-dark-ghost) 1px,transparent 1px);background-size:60px 60px;}
  .hero-inner{position:relative;max-width:1440px;margin:0 auto;padding:0 96px;box-sizing:border-box;}
  
  
  
  
  
  
  .hero-inner h1{font-family:'Noto Serif JP',serif;font-size:clamp(24px,3.2vw,40px);font-weight:700;color:#fff;line-height:1.5;margin-bottom:16px;}
  .hero-inner h1 em{font-style:normal;color:var(--green-vivid);}
  .hero-sub{font-size:16px;color:var(--on-dark-low);max-width:580px;line-height:1.9;border-left:2px solid var(--green-accent);padding-left:16px;margin-bottom:44px;}

  /* Hero reassurance row */
  .reassurance{display:flex;flex-wrap:wrap;gap:10px;}
  .re-tag{display:flex;align-items:center;gap:7px;font-size:16px;color:var(--on-dark-low);background:var(--on-dark-ghost);border:1px solid var(--on-dark-ghost);padding:8px 16px;border-radius:2px;letter-spacing:0.05em;}
  .re-tag::before{content:'✓';color:var(--on-dark-high);font-size:16px;font-weight:700;}

  to{opacity:1;transform:translateY(0)}}
  
  .hero-inner h1{animation:fadeUp 0.65s ease 0.1s both;}
  .hero-sub{animation:fadeUp 0.65s ease 0.2s both;}
  .reassurance{animation:fadeUp 0.65s ease 0.3s both;}

  /* ── MAIN LAYOUT ── */
  .main{width:100%;max-width:1440px;margin:0 auto;padding:144px 96px;display:grid;grid-template-columns:minmax(0,1fr);gap:56px;align-items:start;box-sizing:border-box;}
  .main > *,
  .form-wrap,
  .contact-form,
  .wpcf7,
  .wpcf7-form{min-width:0;max-width:100%;box-sizing:border-box;}

  /* ── FORM COLUMN ── */
  .form-wrap{}
  .form-section-label{
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  letter-spacing: 0.32em;
  color: var(--green-accent);
  font-weight: 600;
  margin-bottom: 8px;
  text-transform: uppercase;
  }
  .form-section-title{
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(24px, 3.7vw, 36px);
  font-weight: 700;
  color: var(--green-dark);
  line-height: 1.5;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
  }
  .form-section-sub{font-size:16px;color:var(--grey-mid);line-height:1.9;margin-bottom:36px;}

  /* TAB METHOD SELECTOR */
  .method-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:36px;}
  .method-tab{background:#fff;padding:16px 12px;text-align:center;cursor:pointer;transition:background 0.2s;border:none;font-family:'Noto Sans JP',sans-serif;}
  .method-tab.active{background:var(--green-dark);}
  .method-tab-icon{font-size:22px;margin-bottom:6px;}
  .method-tab-label{font-size:16px;font-weight:600;letter-spacing:0.06em;}
  .method-tab.active .method-tab-label{color:#fff;}
  .method-tab:not(.active) .method-tab-label{color:var(--grey-mid);}
  .method-tab-sub{font-size:16px;color:var(--grey-light);margin-top:2px;letter-spacing:0.04em;}
  .method-tab.active .method-tab-sub{color:var(--green-muted);}

  /* FORM */
  .hidden-fields-container{display: none;}
  .contact-form{display:flex;flex-direction:column;gap:20px;}
  .form-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;}
  .form-row,
  .form-group,
  .wpcf7-form-control-wrap{min-width:0;}
  .form-group{margin-bottom: 20px;}
  .form-group p{display:flex;flex-direction:column;gap:6px;}
  .wpcf7-form-control-wrap{display:flex;flex-direction:column;gap:6px;}
  .form-group label{font-size:16px;font-weight:600;color:var(--grey-dark);letter-spacing:0.04em;display:flex;align-items:center;gap:8px;}
  .required-badge{font-size:16px;background:var(--green-accent);color:#fff;padding:2px 7px;border-radius:2px;letter-spacing:0.05em;font-weight:500;}
  .optional-badge{font-size:16px;background:var(--border);color:var(--grey-light);padding:2px 7px;border-radius:2px;letter-spacing:0.05em;}
  .form-group input,
  .form-group select,
  .form-group textarea{
    border:1px solid var(--border);
    border-radius:3px;
    padding:12px 16px;
    font-family:'Noto Sans JP',sans-serif;
    font-size:16px;
    color:var(--grey-dark);
    background:#fff;
    transition:border-color 0.2s,box-shadow 0.2s;
    outline:none;
    -webkit-appearance:none;
    width:100%;
    max-width:100%;
    box-sizing:border-box;
  }
  .form-group input:focus,
  .form-group select:focus,
  .form-group textarea:focus{border-color:var(--green-accent);box-shadow:0 0 0 3px rgba(74,145,98,0.12);}
  .form-group input::placeholder,
  .form-group textarea::placeholder{color:var(--grey-light);}
  .form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8a8a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer;}
  .form-group textarea{resize:vertical;min-height:140px;line-height:1.75;}

  /* CHECKBOX GROUP */
  /*.checkbox-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px;width:100%;max-width:100%;min-width:0;box-sizing:border-box;}*/
  .checkbox-grid p,
  .checkbox-grid p span{min-width:0;max-width:100%;box-sizing:border-box;}
  .checkbox-item{display:flex;align-items:center;gap:9px;font-size:16px;color:var(--grey-mid);cursor:pointer;padding:10px 14px;border:1px solid var(--border);border-radius:3px;transition:border-color 0.2s,background 0.2s;user-select:none;}
  .checkbox-item:hover{border-color:var(--green-accent);background:var(--green-pale);}
  .checkbox-item input{width:15px;height:15px;accent-color:var(--green-accent);cursor:pointer;flex-shrink:0;}
  .checkbox-item input:checked + span{color:var(--green-dark);font-weight:600;}
  .checkbox-grid .wpcf7-form-control-wrap{display:block;width:100%;max-width:100%;}
  .checkbox-grid .wpcf7-checkbox{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px;width:100%;max-width:100%;}
  .checkbox-grid .wpcf7-list-item{display:block;margin:0;}
  .checkbox-grid .wpcf7-list-item label{display:flex;align-items:center;gap:9px;font-size:16px;color:var(--grey-mid);cursor:pointer;padding:10px 14px;border:1px solid var(--border);border-radius:3px;transition:border-color 0.2s,background 0.2s;user-select:none;box-sizing:border-box;min-width:0;}
  .checkbox-grid .wpcf7-list-item-label{min-width:0;overflow-wrap:anywhere;}
  .checkbox-grid .wpcf7-list-item label:hover{border-color:var(--green-accent);background:var(--green-pale);}
  .checkbox-grid .wpcf7-list-item input[type="checkbox"]{width:15px;height:15px;appearance:none;-webkit-appearance:none;border:1px solid var(--border);border-radius:2px;background:#fff;cursor:pointer;flex-shrink:0;position:relative;transition:background 0.2s,border-color 0.2s;}
  .checkbox-grid .wpcf7-list-item input[type="checkbox"]:checked{background:var(--green-accent);border-color:var(--green-accent);}
  .checkbox-grid .wpcf7-list-item input[type="checkbox"]:checked::after{content:'';position:absolute;left:50%;top:50%;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:translate(-50%,-58%) rotate(45deg);}
  .checkbox-grid .wpcf7-list-item input:checked + .wpcf7-list-item-label{color:var(--green-dark);font-weight:600;}

  /* PRIVACY */
  .privacy-box{background:var(--grey-pale);border:1px solid var(--border);border-radius:3px;padding:16px 18px;}
  .privacy-box p{font-size:16px;color:var(--grey-light);line-height:1.95;}
  .privacy-box a{color:var(--green-accent);text-decoration:none;}
  .privacy-check{display:flex;align-items:flex-start;gap:10px;margin-top:12px;font-size:16px;color:var(--grey-mid);cursor:pointer;}
  .privacy-check input{margin-top:3px;accent-color:var(--green-accent);flex-shrink:0;}

  /* SUBMIT */
  .submit-area{margin-top: 20px;}
  .submit-area p{display:flex;flex-direction:column;align-items:center;gap:12px;padding-top:4px;}
  .btn-submit{width:100%;box-sizing:border-box;background:var(--green-accent);color:#fff;padding:18px;font-size:16px;font-weight:700;letter-spacing:0.1em;border:none;border-radius:3px;cursor:pointer;transition:background 0.2s,transform 0.2s;font-family:'Noto Sans JP',sans-serif;}
  .btn-submit:hover{background:var(--green-light);transform:translateY(-1px);}
  .submit-note{font-size:16px;color:var(--grey-light);text-align:center;letter-spacing:0.04em;}

  /* SUCCESS MESSAGE */
  .success-msg{display:none;background:var(--green-pale);border:1px solid var(--green-muted);border-radius:4px;padding:32px;text-align:center;}
  .success-msg.show{display:block;}
  .success-msg h3{font-family:'Noto Serif JP',serif;font-size:18px;font-weight:700;color:var(--green-dark);margin-bottom:10px;}
  .success-msg p{font-size:16px;color:var(--grey-mid);line-height:1.9;}
  
  /* ERROR MESSAGE */
  .wpcf7-not-valid-tip{color: #E40003;}
  .screen-reader-response{display: none;}
  
  .wpcf7-response-output{
  	padding: 1em;
	border: 1px solid #4A9162;
	border-radius: 5px;
	color: #4A9162;
  }

  /* ── SIDEBAR ── */
  .sidebar{display:flex;flex-direction:column;gap:20px;}

  /* DIRECT CONTACT CARD */
  .contact-card{background:var(--green-dark);border-radius:4px;padding:32px 28px;position:relative;overflow:hidden;}
  .contact-card::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 80% 20%,rgba(74,145,98,0.2) 0%,transparent 60%);}
  .contact-card-inner{position:relative;}
  .contact-card-label{font-size:16px;letter-spacing:0.22em;color:var(--green-muted);font-weight:500;margin-bottom:14px;text-transform:uppercase;}
  .contact-card h3{font-family:'Noto Serif JP',serif;font-size:16px;font-weight:700;color:#fff;line-height:1.55;margin-bottom:20px;}
  .contact-method{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
  .c-method-btn{display:flex;align-items:center;gap:12px;background:var(--on-dark-ghost);border:1px solid var(--on-dark-ghost);border-radius:3px;padding:14px 16px;text-decoration:none;transition:background 0.2s,border-color 0.2s;}
  .c-method-btn:hover{background:var(--on-dark-ghost);border-color:var(--on-dark-faint);}
  .c-method-icon{font-size:20px;flex-shrink:0;}
  .c-method-text strong{display:block;font-size:16px;font-weight:600;color:#fff;margin-bottom:1px;}
  .c-method-text span{font-size:16px;color:var(--on-dark-low);letter-spacing:0.04em;}
  .contact-card-note{font-size:16px;color:var(--on-dark-faint);line-height:1.7;letter-spacing:0.04em;}

  /* MAIN SITE CARD */
  .main-site-card{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden;transition:box-shadow 0.2s;}
  .main-site-card:hover{box-shadow:0 4px 24px rgba(45,90,61,0.1);}
  .main-site-card-head{background:var(--green-mid);padding:14px 20px;display:flex;align-items:center;gap:10px;}
  .main-site-card-head span{font-size:16px;letter-spacing:0.18em;color:var(--green-muted);text-transform:uppercase;font-weight:500;}
  .ext-icon{font-size:16px;}
  .main-site-card-
  .main-site-card-body h4{font-family:'Noto Serif JP',serif;font-size:16px;font-weight:700;color:var(--green-dark);line-height:1.5;margin-bottom:8px;}
  .main-site-card-body p{font-size:16px;color:var(--grey-mid);line-height:1.95;margin-bottom:16px;}
  .btn-main-site{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;box-sizing:border-box;background:var(--green-pale);border:1px solid var(--green-muted);color:var(--green-mid);padding:12px;font-size:16px;font-weight:600;letter-spacing:0.06em;text-decoration:none;border-radius:3px;transition:background 0.2s,border-color 0.2s;}
  .btn-main-site:hover{background:var(--green-muted);border-color:var(--green-accent);}

  /* FLOW CARD */
  .flow-card{background:var(--grey-pale);border:1px solid var(--border);border-radius:4px;padding:24px 22px;}
  .flow-card-title{font-size:16px;letter-spacing:0.2em;color:var(--green-accent);font-weight:500;margin-bottom:16px;text-transform:uppercase;}
  .flow-steps{display:flex;flex-direction:column;gap:0;}
  .flow-step{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border);}
  .flow-step:last-child{border-bottom:none;}
  .flow-step-num{width:28px;height:28px;background:var(--green-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;color:var(--green-accent);flex-shrink:0;margin-top:2px;}
  .flow-step-text strong{display:block;font-size:16px;font-weight:700;color:var(--green-dark);margin-bottom:2px;}
  .flow-step-text span{font-size:16px;color:var(--grey-light);line-height:1.6;}

  /* FAQ MINI */
  .faq-mini{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden;}
  .faq-mini-head{background:var(--green-dark);padding:14px 20px;font-size:16px;letter-spacing:0.2em;color:var(--green-muted);text-transform:uppercase;font-weight:500;}
  .faq-mini-item{padding:14px 20px;border-bottom:1px solid var(--border);}
  .faq-mini-item:last-child{border-bottom:none;}
  .faq-mini-q{font-size:16px;font-weight:700;color:var(--green-dark);margin-bottom:5px;display:flex;gap:7px;}
  .faq-mini-q::before{content:'Q';color:var(--green-accent);font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;flex-shrink:0;line-height:1;}
  .faq-mini-a{font-size:16px;color:var(--grey-mid);line-height:1.75;padding-left:22px;}

  /* ── RELATED ── */
  

  
  
  

  /* ── FOOTER ── */
  
  
  
  
  
  
  
  
  

  @media(max-width:900px){
    
    .main{grid-template-columns:1fr;}
    .form-row{grid-template-columns:1fr;}
    .checkbox-grid,
    .checkbox-grid .wpcf7-checkbox{grid-template-columns:1fr;}
    
 }
    
  
  
  
  
  
  
  

/* ━━━ PLACEHOLDER IMAGES ━━━ */

/* ─── CONTACT TABS (非表示タブコンテンツ) ─── */
/*.tab-panel            { display:none; }*/
.tab-panel.is-active  { display:block; }
.contact-method-box   { margin-top: 3em; background:var(--grey-pale);border:1px solid var(--border);border-radius:4px;padding:40px 36px;text-align:center; }
.contact-method-icon  { font-size:48px;margin-bottom:16px; }
.contact-method-title { font-family:'Noto Serif JP',serif;font-size:28px;font-weight:700;color:var(--green-dark);margin-bottom:8px;letter-spacing:0.05em; }
.contact-method-title--sm { font-family:'Noto Serif JP',serif;font-size:28px;font-weight:700;color:var(--green-dark);margin-bottom:8px; }
.contact-method-desc  { font-size:16px;color:var(--grey-mid);margin-bottom:24px; }
.contact-method-desc--sm { font-size:16px;color:var(--grey-mid);margin-bottom:8px; }
.contact-method-sub   { font-size:16px;color:var(--grey-light);margin-bottom:24px; }
.contact-method-note  { margin-top:20px;font-size:16px;color:var(--grey-light);line-height:1.95; }
.contact-tel-btn      { display:inline-flex;align-items:center;gap:8px;background:var(--green-accent);color:#fff;padding:16px 40px;font-size:16px;font-weight:700;letter-spacing:0.05em;text-decoration:none;border-radius:2px;transition:background .2s; }
.contact-tel-btn:hover { background:var(--green-light); }
.contact-line-btn     { display:inline-flex;align-items:center;gap:8px;background:var(--green-mid);color:#fff;padding:16px 40px;font-size:16px;font-weight:700;letter-spacing:0.05em;text-decoration:none;border-radius:2px;transition:background .2s; }
.contact-line-btn:hover { background:var(--green-light); }

/* section headings (synced from guide.css) */
.section-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 20px;
  letter-spacing: 0.25em;
  color: var(--green-accent);
  font-weight: 600;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.section-num em {
  font-style: normal;
  font-size: 50px;
  font-weight: 500;
}

.section-title {
  font-family: 'Noto Serif JP', serif;
  font-size: clamp(24px, 3.7vw, 36px);
  font-weight: 700;
  color: var(--green-dark);
  line-height: 1.5;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

/* Mobile layout */
@media (max-width: 900px) {
  .hero {
    padding: 22vw 0 14vw;
  }
  .hero-inner,
  .main {
    padding-left: 5vw;
    padding-right: 5vw;
  }
  .main {
    padding-top: 14vw;
    padding-bottom: 17vw;
    gap: 8vw;
  }
  .method-tabs,
  .form-row,
  .checkbox-grid,
  .checkbox-grid .wpcf7-checkbox {
    grid-template-columns: 1fr;
  }
  .method-tab {
    text-align: left;
  }
  .reassurance {
    display: grid;
  }
  .contact-card,
  .contact-method-box,
  .flow-card {
    padding: 5vw 4vw;
  }
  .contact-tel-btn,
  .contact-line-btn {
    width: 100%;
    justify-content: center;
    padding-left: 4vw;
    padding-right: 4vw;
  }
}

@media (max-width: 480px) {
  .hero-inner,
  .main {
    padding-left: 4vw;
    padding-right: 4vw;
  }
}
