/* p-simulator UI - shared look & feel (WordPress) */
:root{
  --bg:#f6f7fb;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --line:#e2e8f0;
  --brand:#0f766e;
  --brand2:#134e4a;
  --shadow: 0 10px 30px rgba(2,6,23,.08);
  --radius: 16px;
  --radius2: 22px;
  --danger:#ef4444;
}

body{
  background:var(--bg);
  color:var(--text);
  font-family: system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
}

/* WP admin bar 対応 */
body.admin-bar .ps-header{ top: 32px; }
@media (max-width: 782px){
  body.admin-bar .ps-header{ top: 46px; }
}

.wrap{max-width:1240px; margin:0 auto; padding:0 18px;}

/* Header */
.ps-header{
  position:sticky; top:0; z-index:50;
  background:rgba(246,247,251,.88);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 0; gap:14px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:900; letter-spacing:.2px; min-width:160px;
  color:inherit; text-decoration:none;
}
.logo{
  width:34px; height:34px; border-radius:10px;
  background:linear-gradient(135deg,var(--brand),#22c55e);
  box-shadow:0 10px 30px rgba(15,118,110,.22);
  flex:0 0 auto;
}
.brand small{display:block; font-weight:800; color:var(--muted); font-size:11px; margin-top:-2px}

.nav{display:flex; align-items:center; justify-content:flex-end;}
.nav-toggle{
  display:none;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  font-weight:900;
  cursor:pointer;
  white-space:nowrap;
}

/* wp_nav_menu */
.ps-menu{
  list-style:none;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:0;
  padding:0;
  color:var(--muted);
  font-size:14px;
  justify-content:flex-end;
}
.ps-menu li{margin:0; padding:0;}
.ps-menu a{
  display:block;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid transparent;
  color:inherit;
  text-decoration:none;
}
.ps-menu a:hover{
  background:#fff;
  color:var(--text);
  border-color:var(--line);
  box-shadow:0 8px 18px rgba(2,6,23,.06);
}
.ps-menu .current-menu-item > a,
.ps-menu .current_page_item > a{
  background:#fff;
  color:var(--text);
  border-color:var(--line);
  box-shadow:0 8px 18px rgba(2,6,23,.06);
}

/* Page head */
.pagehead{padding:18px 0 10px}
.breadcrumb{color:var(--muted); font-size:13px}
.pagehead h1{margin:6px 0 6px; font-size:22px; letter-spacing:-.3px}
.pagehead p{margin:0; color:var(--muted)}

/* Layout */
.grid{
  display:grid;
  grid-template-columns: 1fr 1.25fr;
  gap:14px;
  padding-bottom:14px;
}
.grid.grid-single{grid-template-columns:1fr;}
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:18px;
  min-width:0;
}
.card h2{margin:0 0 10px; font-size:16px; letter-spacing:-.2px}

/* Contact form styling (generic) */
.ps-entry label, .ps-entry .wpforms-field-label{
  display:block;
  font-size:13px;
  font-weight:900;
  color:var(--text);
  margin:10px 0 6px;
}
.ps-entry input[type="text"],
.ps-entry input[type="email"],
.ps-entry input[type="url"],
.ps-entry input[type="tel"],
.ps-entry input[type="number"],
.ps-entry textarea,
.ps-entry select{
  width:100%;
  padding:12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  font-size:16px;
  outline:none;
}
.ps-entry textarea{min-height:160px; resize:vertical;}
.ps-entry input:focus, .ps-entry textarea:focus, .ps-entry select:focus{
  border-color: rgba(15,118,110,.45);
  box-shadow: 0 0 0 4px rgba(15,118,110,.12);
}

/* submit buttons (Contact Form 7 / WPForms / generic) */
.ps-entry input[type="submit"],
.ps-entry button[type="submit"],
.ps-entry .wpcf7-submit,
.ps-entry .wpforms-submit{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:none;
  cursor:pointer;
  font-weight:900;
  background:linear-gradient(135deg,var(--brand),#22c55e);
  color:#fff;
  box-shadow:0 16px 30px rgba(15,118,110,.20);
}
.ps-entry input[type="submit"]:hover,
.ps-entry button[type="submit"]:hover{
  filter:brightness(.98);
}

/* Messages */
.ps-entry .wpcf7-response-output{
  border-radius:14px;
  border:1px solid var(--line);
  padding:12px 14px;
  margin:12px 0 0;
  background:#fff;
}
.ps-entry .wpcf7-not-valid-tip{color:var(--danger); font-weight:900; font-size:13px;}

/* Details */
.ps-details{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:12px 14px;
  margin-top:12px;
}
.ps-details summary{
  cursor:pointer;
  font-weight:1000;
  list-style:none;
}
.ps-details summary::-webkit-details-marker{display:none}
.ps-details ul{margin:10px 0 0; color:var(--muted); font-size:13px; padding-left:18px}

/* Footer */
.ps-footer{
  border-top:1px solid var(--line);
  margin-top:14px;
  padding:18px 0 26px;
  color:var(--muted);
  font-size:13px;
}
.ps-footer-inner{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  justify-content:space-between;
}
.ps-footer-links{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.ps-footer a{color:inherit; text-decoration:none}
.ps-footer a:hover{text-decoration:underline}

@media (max-width: 980px){
  .grid{grid-template-columns:1fr}
  .nav{display:none; width:100%; justify-content:flex-start}
  .nav.open{display:flex}
  .nav-toggle{display:inline-flex}
  .topbar{flex-wrap:wrap}
  .ps-menu{justify-content:flex-start}
}


/* ===== Contact page tweaks (align left + remove extra whitespace) ===== */
.entry-title,
.pagehead h1{
  text-align:left;
}

.entry-content,
.ps-entry{
  text-align:left;
}

/* Remove theme default spacing around content area */
#content.site-content{
  padding:0;
}
.site-main{
  margin:0;
}
.ps-main{
  padding:0;
}

/* Contact Form 7: remove excessive <p> margins and make layout tight */
.ps-entry .wpcf7{
  margin:0;
}
.ps-entry .wpcf7 form{
  margin:0;
}
.ps-entry .wpcf7 p{
  margin:0 0 12px;
}
.ps-entry .wpcf7 p:last-child{
  margin-bottom:0;
}

/* Make CF7 lists / notices align */
.ps-entry .wpcf7 form .wpcf7-response-output{
  margin-top:12px;
}


/* ===== Contact Form 7 (CF7) - UI enhancement ===== */
.ps-entry .wpcf7 form{
  --cf7-gap: 12px;
}

/* Keep labels consistent */
.ps-entry .wpcf7 label{
  display:block;
  font-size:13px;
  font-weight:900;
  color:var(--text);
  margin:10px 0 6px;
  text-align:left;
}

/* CF7 default often wraps fields in <p>. Make spacing clean. */
.ps-entry .wpcf7 form p{
  margin:0 0 var(--cf7-gap);
}
.ps-entry .wpcf7 form p:last-child{ margin-bottom:0; }

/* Inputs */
.ps-entry .wpcf7 input[type="text"],
.ps-entry .wpcf7 input[type="email"],
.ps-entry .wpcf7 input[type="url"],
.ps-entry .wpcf7 input[type="tel"],
.ps-entry .wpcf7 input[type="number"],
.ps-entry .wpcf7 input[type="date"],
.ps-entry .wpcf7 input[type="time"],
.ps-entry .wpcf7 textarea,
.ps-entry .wpcf7 select{
  width:100%;
  padding:12px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  font-size:16px;
  outline:none;
}

/* Textarea */
.ps-entry .wpcf7 textarea{
  min-height:160px;
  resize:vertical;
}

/* Focus */
.ps-entry .wpcf7 input:focus,
.ps-entry .wpcf7 textarea:focus,
.ps-entry .wpcf7 select:focus{
  border-color: rgba(15,118,110,.45);
  box-shadow: 0 0 0 4px rgba(15,118,110,.12);
}

/* Placeholder tone */
.ps-entry .wpcf7 input::placeholder,
.ps-entry .wpcf7 textarea::placeholder{
  color: rgba(100,116,139,.85);
}

/* Required marker (many CF7 forms use <span class="wpcf7-form-control-wrap"> inside label) */
.ps-entry .wpcf7 .required,
.ps-entry .wpcf7 .wpcf7-not-valid-tip{
  text-align:left;
}

/* Validation: highlight invalid controls */
.ps-entry .wpcf7 .wpcf7-not-valid{
  border-color: rgba(239,68,68,.55) !important;
  box-shadow: 0 0 0 4px rgba(239,68,68,.10);
}

/* Inline validation tip */
.ps-entry .wpcf7 .wpcf7-not-valid-tip{
  margin-top:6px;
  color:var(--danger);
  font-weight:900;
  font-size:13px;
}

/* Radio / Checkbox */
.ps-entry .wpcf7 .wpcf7-list-item{
  display:inline-flex;
  margin:6px 10px 0 0;
}
.ps-entry .wpcf7 .wpcf7-list-item label{
  margin:0;
  font-weight:800;
  font-size:13px;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  gap:8px;
}

/* Make options feel like pills */
.ps-entry .wpcf7 input[type="radio"],
.ps-entry .wpcf7 input[type="checkbox"]{
  width:18px;
  height:18px;
  accent-color: var(--brand);
}

/* Acceptance (privacy/terms) */
.ps-entry .wpcf7 .wpcf7-acceptance label{
  font-weight:800;
  font-size:13px;
  color:var(--muted);
}

/* Submit button (keep existing) + disabled state */
.ps-entry .wpcf7 input[type="submit"],
.ps-entry .wpcf7 button[type="submit"],
.ps-entry .wpcf7 .wpcf7-submit{
  width:100%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:none;
  cursor:pointer;
  font-weight:900;
  background:linear-gradient(135deg,var(--brand),#22c55e);
  color:#fff;
  box-shadow:0 16px 30px rgba(15,118,110,.20);
}
.ps-entry .wpcf7 input[type="submit"]:disabled,
.ps-entry .wpcf7 button[type="submit"]:disabled{
  opacity:.7;
  cursor:not-allowed;
  box-shadow:none;
}

/* Spinner */
.ps-entry .wpcf7 .wpcf7-spinner{
  margin-left:10px;
}

/* Response output (success/error) */
.ps-entry .wpcf7 .wpcf7-response-output{
  border-radius:14px;
  padding:12px 14px;
  margin:12px 0 0;
  background:#fff;
  border:1px solid var(--line);
  color:var(--text);
}
.ps-entry .wpcf7 form.invalid .wpcf7-response-output,
.ps-entry .wpcf7 form.failed .wpcf7-response-output{
  border-color: rgba(239,68,68,.45);
  background: rgba(239,68,68,.06);
}
.ps-entry .wpcf7 form.sent .wpcf7-response-output{
  border-color: rgba(34,197,94,.45);
  background: rgba(34,197,94,.08);
}

/* Screen-reader helper text */
.ps-entry .wpcf7 .screen-reader-response{
  border:0;
}

/* ===== Optional: two-column layout helpers (use in CF7 form markup) =====
   Example:
   <div class="ps-cf7-grid2">
     <span class="ps-cf7-col">[text* your-name placeholder "お名前"]</span>
     <span class="ps-cf7-col">[email* your-email placeholder "メール"]</span>
   </div>
*/
.ps-entry .ps-cf7-grid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.ps-entry .ps-cf7-col{
  display:block;
}
@media (max-width: 980px){
  .ps-entry .ps-cf7-grid2{ grid-template-columns:1fr; }
}
