@charset "UTF-8";

/* ==========================
   Madaraya Mailform Design
========================== */

:root{
  --brand: #2071AD;            /* まだらやの青 */
  --text: #111;
  --muted: rgba(17,17,17,.72);
  --line: rgba(32,113,173,.18);
  --bg: #ffffff;
  --shadow: 0 12px 30px rgba(0,0,0,.06);
}

/* 全体ラッパー */
div#mf_wrapper {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 16px;
  text-align: left;
  font-family: "Zen Old Mincho", serif;
}

/* 見出し（もし使う場合） */
div#mf_header h1 {
  font-size: 26px;
  border-bottom: 1px solid rgba(32,113,173,.25);
  margin: 0 0 8px;
  padding: 0 0 10px;
  color: var(--brand);
  font-weight: 400;
}

div#mf_header h2 {
  font-size: 14px;
  color: rgba(17,17,17,.6);
  font-weight: normal;
  margin: 0;
  padding: 0;
}

/* フォーム全体 */
form#mailform{
  margin-top: 30px;
}

/* テーブルをカードっぽく */
table.mailform{
  width: 100%;
  border-collapse: collapse;
  background: var(--bg);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow);
}

/* 行 */
table.mailform tr{
  border-bottom: 1px solid rgba(17,17,17,.10);
}

table.mailform tr:last-child{
  border-bottom: none;
}

/* th/td */
table.mailform tr th,
table.mailform tr td{
  padding: 18px 20px;
  vertical-align: top;
  font-size: 15px;
  font-weight: 400;
  box-sizing: border-box;
}

/* 左ラベル */
table.mailform tr th{
  width: 240px;
  color: var(--text);
  letter-spacing: .03em;
  background: rgba(32,113,173,.03);
}

/* サブ英語 */
table.mailform tr th p{
  margin: 6px 0 0;
  padding: 0;
  font-size: 12px;
  color: rgba(17,17,17,.55);
  letter-spacing: .06em;
}

/* 必須マーク（※ 赤） */
table.mailform tr th span{
  display: inline-block;
  margin-left: 6px;
  background: none;
  padding: 0;
  border-radius: 0;
  font-size: 14px;
  line-height: 1;
  color: #C00;
  font-weight: 600;
}

/* 入力共通 */
table.mailform input[type="text"],
table.mailform input[type="email"],
table.mailform input[type="tel"],
table.mailform select,
table.mailform textarea{
  width: 50%;              /* ★PCは50% */
  max-width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(17,17,17,.18);
  background: #fff;
  font-size: 15px;
  line-height: 1.6;
  color: var(--text);
  outline: none;
  box-sizing: border-box;
  transition: .2s ease;
}

/* textareaは広めに（使いやすい） */
table.mailform textarea{
  width: 100%;
  height: 160px;
  resize: vertical;
}

/* フォーカス */
table.mailform input:focus,
table.mailform textarea:focus,
table.mailform select:focus{
  border-color: rgba(32,113,173,.55);
  box-shadow: 0 0 0 4px rgba(32,113,173,.15);
}

/* ラジオ・チェック */
table.mailform input[type="radio"],
table.mailform input[type="checkbox"]{
  transform: translateY(1px);
  margin-right: 6px;
  margin-left: 10px;
}

table.mailform td{
  color: var(--muted);
}

/* 住所自動入力ボタン */
table.mailform input[type="button"]{
  display: inline-block;
  margin-left: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(32,113,173,.35);
  background: #fff;
  color: var(--brand);
  font-size: 13px;
  cursor: pointer;
  transition: .2s ease;
}

table.mailform input[type="button"]:hover{
  background: rgba(32,113,173,.06);
}

/* 送信・リセット行 */
table.mailform tr:last-child th{
  background: rgba(32,113,173,.03);
  font-size: 13px;
  color: rgba(17,17,17,.6);
}

/* 送信・リセットボタン */
table.mailform input[type="submit"],
table.mailform input[type="reset"]{
  appearance: none;
  border: none;
  cursor: pointer;
  padding: 14px 26px;
  border-radius: 999px;
  font-size: 15px;
  letter-spacing: .06em;
  transition: .25s ease;
  margin-right: 12px;
}

table.mailform input[type="submit"]{
  background: var(--brand);
  color: #fff;
  box-shadow: 0 10px 18px rgba(32,113,173,.22);
}

table.mailform input[type="submit"]:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 22px rgba(32,113,173,.28);
}

table.mailform input[type="reset"]{
  background: rgba(17,17,17,.06);
  color: rgba(17,17,17,.75);
}

table.mailform input[type="reset"]:hover{
  background: rgba(17,17,17,.10);
}

/* ==========================
   Responsive
========================== */

@media screen and (max-width: 800px){
  table.mailform,
  table.mailform tbody,
  table.mailform tbody tr{
    display: block;
    width: 100%;
  }

  table.mailform tr th,
  table.mailform tr td{
    display: block;
    width: 100%;
    padding: 14px 16px;
  }

  table.mailform tr th{
    border-bottom: none;
    background: rgba(32,113,173,.04);
  }

  table.mailform tr td{
    padding-top: 6px;
  }

  /* ★SPは入力欄を100% */
  table.mailform input[type="text"],
  table.mailform input[type="email"],
  table.mailform input[type="tel"],
  table.mailform select{
    width: 100%;
  }

  table.mailform input[type="submit"],
  table.mailform input[type="reset"]{
    width: 100%;
    margin: 0 0 10px;
  }

  table.mailform input[type="button"]{
    margin: 10px 0 0;
    width: 100%;
  }
}
