/* ke'o ke'o 予約フォーム — スタイル（ホームページと統一：白基調・上品） */
:root{
  --bg:#ffffff; --cream:#f7f4ef; --cream2:#efe9e1;
  --ink:#211c17; --sub:#4a433b; --muted:#7c7266; --line:#e8e2d9;
  --accent:#a98c6d; --accent-dark:#8a6f52; --dark:#2b2622;
  --ok:#4a9d6e; --warn:#c2492f; --disabled:#f2ede7;
  --serif:"Shippori Mincho",serif; --latin:"Cormorant Garamond",serif; --sans:"Noto Sans JP",sans-serif;
  --radius:2px;
}
*{box-sizing:border-box;}
html{background:#ffffff;}
/* ホームページと同じ薄い背景画像レイヤー */
#page-bg{position:fixed;inset:0;z-index:-1;background-size:cover;background-position:center;opacity:.07;display:none;pointer-events:none;}
body{margin:0;font-family:var(--sans);background:transparent;color:var(--ink);line-height:1.9;font-weight:400;font-size:15px;letter-spacing:.02em;-webkit-font-smoothing:antialiased;}

.wrap{max-width:620px;margin:0 auto;padding:40px 20px 72px;}

header.brand{text-align:center;margin-bottom:6px;}
header.brand h1{font-family:"Cormorant Garamond","Shippori Mincho",serif;font-size:2rem;font-weight:500;letter-spacing:.08em;margin:0;color:var(--ink);}
header.brand p{color:var(--muted);font-size:.8rem;letter-spacing:.16em;margin:8px 0 0;}

.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;margin-top:20px;box-shadow:0 1px 3px rgba(43,38,34,.04);}
.card h2{font-family:var(--serif);font-size:1.05rem;font-weight:500;letter-spacing:.08em;margin:0 0 18px;padding-bottom:12px;border-bottom:1px solid var(--line);color:var(--ink);}

.field{display:block;margin:16px 0;}
.field>.lbl{display:block;font-weight:500;font-size:.9rem;letter-spacing:.04em;margin-bottom:8px;color:var(--ink);}
.req{color:var(--warn);font-size:.72rem;margin-left:6px;letter-spacing:.08em;}
.opt{color:var(--muted);font-size:.72rem;margin-left:6px;font-weight:400;}
.hint{color:var(--muted);font-size:.78rem;line-height:1.75;margin:6px 0 0;}

input[type=text],input[type=email],input[type=date],textarea,select{
  width:100%;padding:11px 13px;border:1px solid #cdc3b3;border-radius:var(--radius);font:inherit;font-weight:400;background:#fff;color:var(--ink);
  box-shadow:inset 0 1px 2px rgba(43,38,34,.045);}
textarea{min-height:92px;resize:vertical;}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(169,140,109,.14);}
::placeholder{color:#c7bfb4;}

/* ラジオ */
.radio-row{display:flex;gap:10px;flex-wrap:wrap;}
.radio-row label{flex:1;min-width:120px;cursor:pointer;border:1px solid #cdc3b3;border-radius:var(--radius);padding:12px;text-align:center;background:#fff;font-size:.9rem;letter-spacing:.05em;transition:.15s;}
.radio-row input{display:none;}
.radio-row input:checked+span{font-weight:500;color:var(--accent-dark);}
.radio-row label:has(input:checked){border-color:var(--accent);background:var(--cream);}

/* カレンダー */
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.cal-nav button{border:1px solid var(--line);background:#fff;border-radius:var(--radius);padding:7px 14px;cursor:pointer;font:inherit;font-size:.78rem;letter-spacing:.08em;color:var(--sub);}
.cal-nav button:disabled{opacity:.35;cursor:default;}
.cal-title{font-family:var(--serif);font-weight:500;letter-spacing:.06em;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-dow{text-align:center;font-size:.72rem;color:var(--muted);padding:6px 0;letter-spacing:.05em;}
.cal-grid .cal-dow:nth-child(1){color:#c0392b;}
.cal-grid .cal-dow:nth-child(7){color:#5a7ba6;}
.cal-cell{aspect-ratio:1/1;border-radius:var(--radius);border:1px solid transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.92rem;background:var(--disabled);color:#c7bfb4;}
.cal-cell.empty{background:transparent;}
.cal-cell.open{background:#fff;border-color:#d3c9b9;color:var(--ink);cursor:pointer;transition:.15s;}
.cal-cell.open:hover{border-color:var(--accent);background:var(--cream);}
.cal-cell.selected{background:var(--dark);color:#fff;border-color:var(--dark);}
.cal-cell .rem{font-size:.6rem;line-height:1;margin-top:2px;color:var(--muted);}
.cal-cell.selected .rem{color:#e8e2d9;}
.cal-cell.full .rem{color:var(--warn);}
.cal-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:.72rem;color:var(--muted);margin-top:12px;}
.cal-legend span::before{content:"";display:inline-block;width:11px;height:11px;border-radius:2px;margin-right:6px;vertical-align:-1px;}
.lg-open::before{background:#fff;border:1px solid var(--line);}
.lg-sel::before{background:var(--dark);}
.lg-close::before{background:var(--disabled);}

.selected-day{margin-top:14px;padding:12px 14px;border-radius:var(--radius);background:var(--cream);border:1px solid var(--accent);font-size:.9rem;letter-spacing:.04em;display:none;}
.selected-day.show{display:block;}

/* ご注文内容（種類・セット数） */
.bulk-set{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.8rem;color:var(--muted);margin:8px 0 12px;}
.bulk-set select{width:auto;padding:7px 10px;}
.bulk-set button{padding:7px 12px;border:1px solid var(--accent);background:#fff;color:var(--accent-dark);border-radius:var(--radius);font:inherit;font-size:.78rem;cursor:pointer;letter-spacing:.06em;}
.dtype{border:1px solid #d6cdbd;border-radius:var(--radius);padding:14px;margin-bottom:10px;background:#fff;}
.dtype-head{display:flex;justify-content:space-between;align-items:center;font-family:var(--serif);font-size:.86rem;color:var(--accent-dark);margin-bottom:8px;letter-spacing:.06em;}
.dtype-head .rm{border:none;background:none;color:var(--muted);cursor:pointer;font-size:1.1rem;line-height:1;padding:0 4px;}
.dtype .dt-title{margin-bottom:8px;}
.dt-set{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:8px;font-size:.85rem;}
.dt-set label{display:inline-flex;align-items:center;gap:5px;cursor:pointer;}
.dt-set select{width:auto;padding:7px 10px;}
.dt-set select:disabled{opacity:.4;}
.add-type-btn{margin-top:2px;padding:10px 16px;border:1px solid var(--line);background:#fff;color:var(--sub);border-radius:var(--radius);font:inherit;font-size:.82rem;cursor:pointer;letter-spacing:.08em;}
.add-type-btn:hover{border-color:var(--accent);color:var(--accent-dark);}
.order-summary{margin-top:14px;padding:14px;border-radius:var(--radius);background:var(--cream);border:1px solid var(--accent);font-family:var(--serif);font-weight:500;font-size:1rem;color:var(--ink);text-align:center;letter-spacing:.08em;}

/* 画像 */
.img-drop{border:1px dashed var(--line);border-radius:var(--radius);padding:22px;text-align:center;color:var(--muted);cursor:pointer;background:#fff;font-size:.82rem;letter-spacing:.04em;}
.img-drop:hover{border-color:var(--accent);color:var(--accent-dark);}
.img-previews{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.img-thumb{position:relative;width:76px;height:76px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);}
.img-thumb img{width:100%;height:100%;object-fit:cover;}
.img-thumb button{position:absolute;top:2px;right:2px;width:20px;height:20px;border:none;border-radius:50%;background:rgba(43,38,34,.6);color:#fff;cursor:pointer;font-size:12px;line-height:20px;padding:0;}

/* 注意事項（ホームページ「ご注文前に」と統一：— のリスト） */
.agreement{background:none;border:none;border-radius:0;padding:0;max-height:none;overflow:visible;font-size:.86rem;line-height:1.85;color:var(--sub);}
.agreement ul{list-style:none;margin:0;padding:0;}
.agreement li{position:relative;padding:13px 0 13px 26px;border-bottom:1px solid var(--line);}
.agreement li:last-child{border-bottom:none;}
.agreement li::before{content:"—";position:absolute;left:0;color:var(--accent);}
.agree-check{display:flex;gap:10px;align-items:flex-start;margin-top:14px;}
.agree-check input{margin-top:4px;width:17px;height:17px;flex-shrink:0;accent-color:var(--dark);}

/* 送信ボタン */
.submit-btn{width:100%;margin-top:26px;padding:17px;border:1px solid var(--dark);border-radius:var(--radius);font-size:.92rem;font-weight:400;letter-spacing:.2em;background:var(--dark);color:#fff;cursor:pointer;transition:.2s;}
.submit-btn:hover{background:#3a332d;}
.submit-btn:disabled{background:#d8d0c6;border-color:#d8d0c6;color:#fff;cursor:not-allowed;}

.form-msg{margin-top:14px;padding:12px 14px;border-radius:var(--radius);font-size:.86rem;display:none;}
.form-msg.show{display:block;}
.form-msg.error{background:#fbeeeb;color:var(--warn);border:1px solid #ecccc3;}
.form-msg.info{background:#eef4ef;color:var(--ok);border:1px solid #cde3d4;}

.delivery-note{font-size:.82rem;line-height:1.8;}
.delivery-note a{color:var(--accent-dark);}

/* 完了画面 */
#complete{display:none;text-align:center;padding:40px 20px;}
#complete.show{display:block;}
#complete .big{font-family:var(--serif);font-size:1.4rem;font-weight:500;letter-spacing:.08em;margin-bottom:12px;color:var(--ink);}
#complete p{color:var(--sub);font-size:.9rem;line-height:1.9;}
.line-btn{display:inline-block;margin-top:18px;padding:14px 30px;border-radius:var(--radius);background:#06c755;color:#fff;text-decoration:none;font-weight:500;letter-spacing:.08em;}

.loading{opacity:.5;pointer-events:none;}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px;margin-right:8px;}
@keyframes spin{to{transform:rotate(360deg);}}
