/* ===== 下層ページ（フォーム・制作実績）共通 ===== */

/* ---------- Subhero ---------- */
.subhero{
  background:linear-gradient(180deg,var(--bg-tint) 0%,var(--bg) 100%);
  padding:64px 0 48px;
}
.subhero h1{font-size:clamp(28px,3.6vw,42px);font-weight:900;margin-top:14px}
.crumb{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:16px;font-size:13px;color:var(--muted)}
.crumb a:hover{color:var(--brand-deep)}
.crumb .sep{color:var(--line)}
.subhero .sub-lead{margin-top:14px;max-width:46em;color:var(--body)}

/* ---------- Form ---------- */
.form-card{
  max-width:860px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);
  padding:clamp(28px,4.5vw,56px);
}
.form-note{max-width:860px;margin:0 auto 22px;font-size:var(--fs-small);color:var(--body)}
.field{margin-bottom:28px}
.field:last-of-type{margin-bottom:0}
.lbl{
  display:flex;align-items:center;gap:10px;
  font-weight:700;color:var(--ink);font-size:15.5px;
  margin-bottom:10px;
}
.req-badge,.opt-badge{
  flex:none;font-size:11px;font-weight:700;border-radius:5px;padding:2px 9px;line-height:1.6;
}
.req-badge{background:var(--brand);color:#fff}
.opt-badge{background:var(--bg-tint);color:var(--brand-dark)}
.field input[type="text"],
.field input[type="email"],
.field input[type="tel"],
.field input[type="url"],
.field input[type="number"],
.field select,
.field textarea{
  width:100%;
  border:1.5px solid var(--line);border-radius:12px;
  padding:13px 16px;font-size:16px;font-family:inherit;color:var(--ink);
  background:#fff;transition:border-color .16s,box-shadow .16s;
  -webkit-appearance:none;appearance:none;
}
.field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B86A8' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:16px;
  padding-right:42px;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(42,161,194,.16);
}
.field textarea{min-height:160px;resize:vertical;line-height:1.8}
.field .anno{font-size:12.5px;color:var(--muted);margin-top:7px;line-height:1.7}
.field-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.tel-row input{width:240px;text-align:left}
.tel-row .dash{color:var(--muted)}
.mail-stack input + input{margin-top:10px}
.zip-row input{width:170px}
.zip-row .zipmark{color:var(--ink);font-weight:700}
.pref-select{max-width:240px;margin-top:10px}
.addr-input{margin-top:10px}

/* validation errors */
.has-error input[type="text"],
.has-error input[type="email"],
.has-error input[type="tel"],
.has-error input[type="url"],
.has-error select,
.has-error textarea{border-color:#E54B4B !important;box-shadow:0 0 0 3px rgba(229,75,75,.14) !important}
.has-error .choice-row{padding:10px 14px;border:1.5px solid #E54B4B;border-radius:10px;background:rgba(229,75,75,.04)}
.field-error{margin-top:7px;font-size:13px;color:#C0392B;font-weight:500;line-height:1.5;display:flex;align-items:center;gap:5px}
.field-error::before{content:"!";display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#E54B4B;color:#fff;font-size:11px;font-weight:700;flex:none}

/* radio / checkbox */
.choice-row{display:flex;gap:10px 22px;flex-wrap:wrap}
.choice-row label{
  display:inline-flex;align-items:center;gap:9px;
  font-size:15.5px;color:var(--ink-soft);cursor:pointer;
}
.choice-row input[type="radio"],
.choice-row input[type="checkbox"]{
  width:19px;height:19px;accent-color:var(--brand-deep);cursor:pointer;flex:none;
}
.choice-col{flex-direction:column;align-items:flex-start;display:flex;gap:10px}
#etc{display:block;margin-top:10px;width:100%}

/* consent + submit */
.consent{
  margin-top:38px;padding-top:30px;border-top:1px dashed var(--line);
  text-align:center;font-size:14px;color:var(--body);
}
.consent a{color:var(--brand-deep);font-weight:700;text-decoration:underline}
.consent .warn{margin-top:12px}
.consent .agree{display:inline-flex;align-items:center;gap:10px;margin-top:10px;cursor:pointer;color:var(--ink);font-weight:500}
.consent .agree input{width:19px;height:19px;accent-color:var(--brand-deep);flex:none}
.submit-wrap{text-align:center;margin-top:26px}
#submit{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(140deg,var(--brand),var(--brand-deep));color:#fff;
  font-weight:700;font-size:16.5px;font-family:inherit;
  padding:17px 56px;border-radius:999px;border:none;cursor:pointer;
  box-shadow:0 18px 38px -16px rgba(15,92,115,.8);
  transition:transform .2s,opacity .2s;
}
#submit:hover:not(:disabled){transform:translateY(-2px)}
#submit:disabled,#submit.off{opacity:.4;cursor:not-allowed;transform:none}

/* ---------- 診断ページ：3つのポイント ---------- */
.points-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:64px}
.point{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);padding:28px 26px;
}
.point .pt-ico{
  width:46px;height:46px;border-radius:13px;background:var(--bg-tint);
  display:grid;place-items:center;color:var(--brand-deep);margin-bottom:16px;
}
.point .pt-ico svg{width:24px;height:24px}
.point h3{font-size:17px;line-height:1.6;margin-bottom:8px}
.point p{font-size:14px;line-height:1.85}

/* ---------- 制作実績 ---------- */
.filterbar{
  max-width:860px;margin:0 auto 44px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);
  padding:20px 24px;
  display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;
}
.filterbar .f-item{flex:1 1 200px}
.filterbar .f-item span{display:block;font-size:12.5px;font-weight:700;color:var(--ink);margin-bottom:7px}
.filterbar select{
  width:100%;border:1.5px solid var(--line);border-radius:11px;
  padding:11px 42px 11px 14px;font-size:15px;font-family:inherit;color:var(--ink);background:#fff;
  -webkit-appearance:none;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B86A8' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;background-size:15px;
}
.filterbar select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(42,161,194,.16)}
.pf-count{max-width:860px;margin:0 auto 20px;font-size:14px;color:var(--muted)}
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pf-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;
}
.pf-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pf-card .pf-shot{aspect-ratio:4/3;background:var(--bg-tint);overflow:hidden;display:flex;align-items:center;justify-content:center}
.pf-card .pf-shot img{width:100%;height:100%;object-fit:contain;object-position:center}
.pf-card .pf-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:4px;flex:1}
.pf-card .pf-name{font-weight:700;color:var(--ink);font-size:15.5px;line-height:1.55}
.pf-card .pf-add{font-size:12.5px;color:var(--muted)}
.pf-card .pf-url{font-size:12px;color:var(--brand-deep);word-break:break-all;margin-top:auto;padding-top:6px}
.pf-empty{
  max-width:860px;margin:0 auto;text-align:center;color:var(--muted);
  background:var(--bg-soft);border:1px dashed var(--line);border-radius:var(--r);
  padding:48px 20px;
}

/* ===== Form + sidebar layout ===== */
.form-layout{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start;max-width:1140px;margin:0 auto}
.form-layout .form-card{max-width:none;margin:0}
.form-sidebar{position:sticky;top:88px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:28px 24px;text-align:center}
.contact-card-label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.contact-card-tel{display:flex;align-items:center;justify-content:center;gap:7px;font-family:"Outfit","Zen Kaku Gothic New",sans-serif;font-weight:700;font-size:22px;color:var(--ink);letter-spacing:.02em;line-height:1.2}
.contact-card-tel svg{width:19px;height:19px;color:var(--brand);flex:none;stroke:var(--brand);stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.contact-card-hours{margin-top:10px;font-size:15px;color:var(--body)}
.contact-card-note{margin-top:16px;font-size:12.5px;color:var(--muted);line-height:1.7;border-top:1px dashed var(--line);padding-top:14px;text-align:left}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .form-layout{grid-template-columns:1fr}
  .form-sidebar{position:static}
  .form-layout .form-card{max-width:860px;margin:0 auto}
}
@media (max-width:900px){
  .points-grid{grid-template-columns:1fr}
  .pf-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .form-card{padding:26px 18px;border-radius:var(--r)}
  .pf-grid{grid-template-columns:1fr}
  .tel-row input{width:100%}
  .choice-row{gap:10px 16px}
  #submit{width:100%}
}

/* ===== Pagination ===== */
.pf-pagination{margin-top:40px;margin-bottom:8px}
.pf-pages{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}
.pg-btn{
  min-width:38px;height:38px;padding:0 12px;
  border:1.5px solid var(--border,#d8e4ea);
  border-radius:8px;
  background:#fff;
  color:var(--ink);
  font-size:14px;font-family:inherit;
  cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
  line-height:1;
}
.pg-btn:hover:not([disabled]){border-color:var(--brand);color:var(--brand)}
.pg-btn.pg-active{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:700}
.pg-btn[disabled]{opacity:.35;cursor:default}
.pg-arrow{font-size:20px}
.pg-ellipsis{color:var(--muted,#9bb);padding:0 4px;line-height:38px}
