/* ===== Contact School & Thanks School ===== */
:root{
  --mint-50:#F0FBFB;--mint-100:#D4F4F4;--mint-200:#A8E8E8;--mint-300:#6DD8D8;
  --mint-400:#38C4C4;--mint-500:#22ABAB;--mint-600:#1A9090;--mint-700:#147575;
  --mint-800:#0E5B5B;--mint-900:#094444;
  --gray-50:#F9F8F6;--gray-100:#F2F0ED;--gray-200:#E4E1DC;--gray-300:#CCC9C3;
  --gray-400:#A09D97;--gray-500:#7D7A74;--gray-600:#5C5A55;--gray-700:#3E3D39;
  --gray-800:#2A2927;--gray-900:#1A1918;
  --font-heading:'Zen Kaku Gothic New','Noto Sans JP',sans-serif;
  --font-body:'Noto Sans JP',sans-serif;
  --font-logo:'M PLUS Rounded 1c',sans-serif;
  --font-en:'DM Sans',sans-serif;
  --content-width:1200px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--gray-800);background:#fff;line-height:1.8;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:var(--content-width);margin:0 auto;padding:0 24px}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100000;background:rgba(255,255,255,0.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(0,0,0,0.05)}
.header-inner{max-width:var(--content-width);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{position:relative;display:inline-block;padding-bottom:6px;overflow:visible}
.logo-text{font-family:var(--font-logo);font-weight:900;font-size:22px;letter-spacing:0.01em;line-height:1;color:#2C2C2A}
.logo::after{content:'';position:absolute;bottom:0;left:0;right:-15%;height:4px;background:var(--mint-500);border-radius:0 0 50% 50%/0 0 100% 100%}

/* ===== Contact Hero ===== */
.contact-hero{padding:120px 0 48px;background:linear-gradient(160deg,var(--mint-800) 0%,var(--mint-900) 50%,#0D3B2D 100%);text-align:center;position:relative;overflow:hidden}
.contact-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(42,172,172,0.12) 0%,transparent 70%)}
.contact-hero .section-label{font-family:var(--font-en);font-size:13px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;color:var(--mint-300);margin-bottom:14px}
.contact-hero .section-title{font-family:var(--font-heading);font-size:clamp(24px,4vw,34px);font-weight:700;color:#fff;line-height:1.45;margin-bottom:12px}
.contact-hero-sub{font-size:14px;color:rgba(255,255,255,0.6)}

/* ===== Form Section ===== */
.contact-form-section{padding:64px 0 80px;background:var(--gray-50)}
.contact-form-card{max-width:640px;margin:0 auto;background:#fff;border-radius:20px;padding:48px 40px;box-shadow:0 4px 24px rgba(0,0,0,0.04)}
.contact-form-info{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--gray-100)}
.contact-form-info-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-500)}
.contact-form-info-item svg{color:var(--mint-500);flex-shrink:0}

/* ===== CF7 Form Styling ===== */
.contact-form-card .wpcf7{margin:0;padding:0}
.contact-form-card .wpcf7-form{margin:0;padding:0}
.form-group{margin-bottom:24px}
.form-label{display:block;font-family:var(--font-heading);font-size:14px;font-weight:500;color:var(--gray-700);margin-bottom:8px}
.form-label .required{font-size:11px;color:#fff;background:var(--mint-500);padding:1px 6px;border-radius:4px;margin-left:6px;font-weight:500}
.form-label .optional{font-size:11px;color:var(--gray-400);background:var(--gray-100);padding:1px 6px;border-radius:4px;margin-left:6px;font-weight:400}

/* CF7 input overrides */
.contact-form-card input[type="text"],
.contact-form-card input[type="email"],
.contact-form-card input[type="tel"],
.contact-form-card .wpcf7-text,
.contact-form-card .wpcf7-email,
.contact-form-card .wpcf7-textarea,
.contact-form-card select,
.contact-form-card .wpcf7-select,
.contact-form-card textarea{
  width:100%!important;padding:12px 16px!important;font-family:var(--font-body)!important;font-size:15px!important;
  color:var(--gray-800)!important;border:1.5px solid var(--gray-200)!important;border-radius:10px!important;
  background:#fff!important;transition:border-color 0.2s,box-shadow 0.2s;outline:none!important;
  -webkit-appearance:none!important;box-sizing:border-box!important;
}
.contact-form-card input:focus,
.contact-form-card select:focus,
.contact-form-card textarea:focus{border-color:var(--mint-400)!important;box-shadow:0 0 0 3px rgba(34,171,171,0.1)!important}
.contact-form-card input::placeholder{color:var(--gray-300)}
.contact-form-card select{
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23A09D97' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")!important;
  background-repeat:no-repeat!important;background-position:right 16px center!important;padding-right:40px!important;
}
.contact-form-card textarea{min-height:120px!important;resize:vertical}

/* Radio & Checkbox */
.contact-form-card .wpcf7-radio,
.contact-form-card .wpcf7-checkbox{display:flex;flex-wrap:wrap;gap:12px}
.contact-form-card .wpcf7-list-item{margin:0!important;display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--gray-700)}
.contact-form-card .wpcf7-list-item input[type="radio"],
.contact-form-card .wpcf7-list-item input[type="checkbox"]{width:18px!important;height:18px!important;accent-color:var(--mint-500);padding:0!important;border:none!important}
.contact-form-card .wpcf7-list-item-label{font-size:14px;color:var(--gray-700)}

/* Session date radio (custom styled) */
.session-radio-wrap .wpcf7-radio{flex-direction:column;gap:10px}
.session-radio-wrap .wpcf7-list-item{padding:12px 16px;border:1.5px solid var(--gray-200);border-radius:10px;transition:border-color 0.2s,background 0.2s;width:100%}
.session-radio-wrap .wpcf7-list-item:has(input:checked){border-color:var(--mint-500);background:var(--mint-50)}
.session-radio-wrap .wpcf7-list-item-label{font-family:var(--font-heading);font-size:15px;font-weight:500;color:var(--gray-800)}

/* Checkbox agreement */
.form-check-wrap .wpcf7-checkbox{flex-direction:column;gap:10px}
.form-check-wrap .wpcf7-list-item{font-size:13px;color:var(--gray-600);line-height:1.6}
.form-check-wrap .wpcf7-list-item input[type="checkbox"]{margin-top:2px;flex-shrink:0}
.form-check-wrap a{color:var(--mint-500);font-weight:500}

/* Validation */
.contact-form-card .wpcf7-not-valid-tip{font-size:12px;color:#d44;margin-top:4px}
.contact-form-card .wpcf7-response-output{border:none!important;padding:16px!important;border-radius:10px!important;font-size:14px;text-align:center;margin:24px 0 0!important}
.contact-form-card .wpcf7-mail-sent-ok{background:var(--mint-50);color:var(--mint-700)}
.contact-form-card .wpcf7-validation-errors{background:#FFF5F5;color:#d44}

.form-note{font-size:12px;color:var(--gray-400);margin-top:4px}

/* Submit */
.contact-form-card .wpcf7-submit,
.form-submit{display:flex;align-items:center;justify-content:center;gap:10px;width:100%!important;padding:16px 32px!important;
  background:linear-gradient(135deg,var(--mint-400),var(--mint-500))!important;color:#fff!important;border:none!important;
  border-radius:32px!important;font-family:var(--font-heading)!important;font-size:16px!important;font-weight:700!important;
  cursor:pointer;box-shadow:0 4px 20px rgba(30,148,148,0.3);transition:transform 0.2s,box-shadow 0.2s;margin-top:32px}
.contact-form-card .wpcf7-submit:hover,
.form-submit:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(30,148,148,0.4)}

/* CF7 spinner */
.contact-form-card .wpcf7-spinner{margin:16px auto 0;display:block}

/* ===== Footer (simple) ===== */
.site-footer-simple{padding:32px 0;background:var(--gray-900);text-align:center}
.footer-copy{font-family:var(--font-en);font-size:12px;color:rgba(255,255,255,0.3)}

/* ===== Thanks Page ===== */
.thanks-section{min-height:calc(100vh - 72px - 80px);display:flex;align-items:center;justify-content:center;padding:120px 24px 80px;background:linear-gradient(180deg,var(--gray-50) 0%,#fff 100%)}
.thanks-card{max-width:560px;text-align:center}
.thanks-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--mint-400),var(--mint-500));display:flex;align-items:center;justify-content:center;margin:0 auto 28px;box-shadow:0 8px 24px rgba(30,148,148,0.2)}
.thanks-title{font-family:var(--font-heading);font-size:clamp(22px,4vw,28px);font-weight:700;color:var(--gray-900);margin-bottom:16px;line-height:1.4}
.thanks-text{font-size:15px;color:var(--gray-600);line-height:1.8;margin-bottom:32px}
.thanks-text strong{color:var(--gray-800)}
.thanks-btns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.thanks-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;border-radius:28px;font-family:var(--font-heading);font-size:14px;font-weight:500;transition:transform 0.2s,box-shadow 0.2s}
.thanks-btn:hover{transform:translateY(-2px)}
.thanks-btn-primary{background:linear-gradient(135deg,var(--mint-400),var(--mint-500));color:#fff;box-shadow:0 4px 16px rgba(30,148,148,0.25)}
.thanks-btn-secondary{background:#fff;color:var(--gray-700);border:1px solid var(--gray-200);box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.thanks-line{display:flex;align-items:center;gap:8px;margin-top:24px;justify-content:center}
.thanks-line a{font-size:13px;color:var(--mint-600);font-weight:500}

/* ===== Cocoon Overrides ===== */
.coconova-contact-page *,
.coconova-thanks-page *{box-sizing:border-box!important}
.coconova-contact-page h1,
.coconova-contact-page h2,
.coconova-thanks-page h1,
.coconova-thanks-page h2{background:none!important;border:none!important;padding:0!important}
.coconova-contact-page .container,
.coconova-thanks-page .container{padding:0 24px!important}
.coconova-contact-page img,
.coconova-thanks-page img{border:none!important}
.coconova-contact-page .article,
.coconova-thanks-page .article{padding:0!important;margin:0!important}
.coconova-contact-page #content,.coconova-contact-page .content,
.coconova-thanks-page #content,.coconova-thanks-page .content{margin:0!important;padding:0!important;max-width:none!important}
.coconova-contact-page .entry-content,
.coconova-thanks-page .entry-content{padding:0!important;margin:0!important}

/* ===== Responsive ===== */
@media(max-width:768px){
  .contact-hero{padding:100px 0 40px}
  .contact-form-card{padding:32px 20px!important;border-radius:16px;margin:0 4px}
  .contact-form-info{flex-direction:column;gap:8px}
  .thanks-section{padding:100px 20px 60px}
  .coconova-contact-page .container,
  .coconova-thanks-page .container{padding:0 20px!important}
}
@media(max-width:480px){
  .coconova-contact-page .container,
  .coconova-thanks-page .container{padding:0 16px!important}
  .contact-form-card{padding:24px 16px!important}
}
