/* ============================================================
   共通メールフォーム スタイル（.afmf にスコープ）
   ・どのサイトに貼っても同じ見た目。サイト差は下のテーマ変数だけ。
   ・<form class="afmf afmf--corp"> … コーポレート（白基調・赤）
   ・<form class="afmf afmf--lp">   … LP（赤背景に白カード・金ボタン）
   ============================================================ */
.afmf{
  /* ▼ サイトごとに切り替えるのはこの変数群だけ ▼ */
  --afmf-card-bg:#f5f6f8;
  --afmf-field-bg:#ffffff;
  --afmf-border:#e6e8eb;
  --afmf-text:#1a1c1f;
  --afmf-muted:#6b7280;
  --afmf-accent:#d6291f;
  --afmf-req-bg:#d6291f;
  --afmf-opt-bg:#cfd4da;
  --afmf-submit-bg:#d6291f;
  --afmf-submit-ink:#ffffff;
  --afmf-radius:14px;
  --afmf-field-radius:10px;
  /* ▲ ここまで ▲ */
  font:inherit;
  color:var(--afmf-text);
  text-align:left;            /* ページ側の中央寄せ等を継承しない（LP対策） */
}
.afmf *,.afmf *::before,.afmf *::after{box-sizing:border-box}

/* テーマ：LP（赤背景に白カード・送信ボタンは金） */
.afmf--lp{
  --afmf-card-bg:#ffffff;
  --afmf-border:#f1cccc;
  --afmf-accent:#CC0000;
  --afmf-req-bg:#CC0000;
  --afmf-submit-bg:#FFD700;
  --afmf-submit-ink:#7a1300;
  --afmf-radius:16px;
  /* LPは横幅いっぱいの暗色セクション直下に置かれるため、幅を制限して中央寄せ
     （ページ他セクションの max-width:720px に合わせる） */
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}

.afmf-card{background:var(--afmf-card-bg);border:1px solid var(--afmf-border);border-radius:var(--afmf-radius);padding:26px}
.afmf-sec{font-size:1.05rem;font-weight:800;margin:6px 0 16px;padding-bottom:8px;border-bottom:2px solid var(--afmf-accent);color:var(--afmf-text)}
.afmf-sec:not(:first-child){margin-top:30px}

.afmf-field{margin-bottom:18px}
.afmf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.afmf-row{grid-template-columns:1fr}}
.afmf-field > label,.afmf-grouplabel{display:block;font-weight:700;font-size:.92rem;margin-bottom:7px}

.afmf input[type=text],.afmf input[type=email],.afmf input[type=tel],.afmf textarea,.afmf select{
  width:100%;padding:.75em .9em;border:1px solid var(--afmf-border);border-radius:var(--afmf-field-radius);
  font-size:1rem;font-family:inherit;background:var(--afmf-field-bg);color:var(--afmf-text)}
.afmf .afmf-zip{max-width:260px}
.afmf select{appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--afmf-muted) 50%),linear-gradient(135deg,var(--afmf-muted) 50%,transparent 50%);
  background-position:calc(100% - 18px) 1.1em,calc(100% - 13px) 1.1em;background-size:5px 5px,5px 5px;background-repeat:no-repeat}
.afmf input:focus,.afmf textarea:focus,.afmf select:focus{outline:none;border-color:var(--afmf-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--afmf-accent) 18%,transparent)}
.afmf textarea{resize:vertical}
.afmf input[type=file]{width:100%;font-size:.9rem;padding:8px;border:1px dashed var(--afmf-border);border-radius:var(--afmf-field-radius);background:var(--afmf-field-bg)}

.afmf-req{background:var(--afmf-req-bg);color:#fff;font-size:.66rem;padding:.15em .55em;border-radius:5px;margin-left:6px;vertical-align:middle}
.afmf-opt{background:var(--afmf-opt-bg);color:#fff;font-size:.66rem;padding:.15em .55em;border-radius:5px;margin-left:6px;vertical-align:middle}

.afmf-radios{display:flex;flex-wrap:wrap;gap:14px}
.afmf-radios label{font-weight:600;display:flex;align-items:center;gap:6px;margin:0}

.afmf-hint{font-size:.82rem;color:var(--afmf-muted);margin:7px 0 0}
.afmf-hint a,.afmf-check a{color:var(--afmf-accent);text-decoration:underline}
.afmf-check label{font-weight:600;display:flex;align-items:flex-start;gap:8px;font-size:.92rem}
.afmf-check input{margin-top:.2em}

/* エラー表示（JS/PHPで .has-error を付与） */
.afmf .has-error input,.afmf .has-error select,.afmf .has-error textarea{border-color:var(--afmf-accent);background:#fff6f5}
.afmf-error{display:none;color:var(--afmf-accent);font-size:.82rem;font-weight:700;margin:6px 0 0}
.afmf .has-error .afmf-error{display:block}

/* 商品ブロック */
.afmf-item{border:1px solid var(--afmf-border);border-radius:12px;padding:16px;margin-bottom:14px;background:rgba(255,255,255,.55)}
.afmf-item__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.afmf-item__no{font-weight:800;font-size:.95rem;background:var(--afmf-accent);color:#fff;border-radius:999px;padding:.15em .9em}
.afmf-item__del{border:1px solid var(--afmf-border);background:var(--afmf-field-bg);color:var(--afmf-muted);border-radius:8px;font-size:.8rem;padding:.35em .8em;cursor:pointer}
.afmf-item__del:hover{color:var(--afmf-accent);border-color:var(--afmf-accent)}
.afmf-additem{border:1px dashed var(--afmf-accent);background:transparent;color:var(--afmf-accent);font-weight:700;border-radius:var(--afmf-field-radius);padding:.7em 1.2em;cursor:pointer;font-family:inherit;font-size:.95rem;margin-bottom:4px}

/* ハニーポット（人間には見えない。ボット対策） */
.afmf-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden}

.afmf-submit{width:100%;border:0;border-radius:999px;cursor:pointer;font-family:inherit;font-weight:800;font-size:1.08rem;padding:1.05em 1.4em;margin-top:18px;
  background:var(--afmf-submit-bg);color:var(--afmf-submit-ink);box-shadow:0 6px 16px color-mix(in srgb,var(--afmf-submit-bg) 35%,transparent);transition:transform .1s}
.afmf-submit:hover{transform:translateY(-2px)}
.afmf-submit:disabled{opacity:.6;cursor:default;transform:none}
.afmf-note{margin-top:12px;font-size:.8rem;color:var(--afmf-muted);text-align:center}
.afmf-formerror{display:none;margin-top:12px;padding:.8em 1em;border-radius:10px;background:#fff6f5;border:1px solid var(--afmf-accent);color:var(--afmf-accent);font-size:.9rem;font-weight:700}
