/* ===== 菊池牧場 カート（デモ） ===== */
.addcart{cursor:pointer;font-family:inherit;background:transparent}
/* ヘッダーのカートボタン */
.cart-btn{position:relative;background:transparent;border:1.5px solid var(--green-d);color:var(--green-d);border-radius:980px;padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:6px}
.cart-btn:hover{background:var(--green-d);color:#fff}
.cart-count{position:absolute;top:-7px;right:-7px;min-width:19px;height:19px;border-radius:999px;background:var(--rust);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px}
.cart-count:empty,.cart-count[data-n="0"]{display:none}

/* ドロワー */
.cart-ov{position:fixed;inset:0;background:rgba(20,30,22,.45);opacity:0;visibility:hidden;transition:.25s;z-index:1000}
.cart-ov.on{opacity:1;visibility:visible}
.cart-dw{position:fixed;top:0;right:0;height:100%;width:min(440px,100%);background:var(--cream,#faf6ef);box-shadow:-10px 0 40px rgba(0,0,0,.18);transform:translateX(100%);transition:.28s;z-index:1001;display:flex;flex-direction:column}
.cart-dw.on{transform:none}
.cart-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line,#e8ddc9);background:#fff}
.cart-hd h3{font-family:'Shippori Mincho',serif;font-size:18px;color:var(--green-d,#26402f);margin:0}
.cart-x{background:none;border:0;font-size:26px;line-height:1;color:var(--sub,#7c6c58);cursor:pointer}
.cart-body{flex:1;overflow-y:auto;padding:16px 20px}
.cart-empty{color:var(--sub,#7c6c58);font-size:14px;text-align:center;padding:48px 0}
.ci{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line,#e8ddc9)}
.ci-th{width:62px;height:62px;border-radius:10px;overflow:hidden;flex-shrink:0;background:#ece5d6;display:flex;align-items:center;justify-content:center;font-size:20px}
.ci-th img{width:100%;height:100%;object-fit:cover}
.ci-mn{flex:1;min-width:0}
.ci-nm{font-size:13.5px;font-weight:700;color:var(--ink,#382c22);line-height:1.4}
.ci-pr{font-size:12.5px;color:var(--sub,#7c6c58);margin-top:3px}
.ci-qty{display:inline-flex;align-items:center;border:1px solid var(--line,#e8ddc9);border-radius:8px;margin-top:8px;background:#fff}
.ci-qty button{width:28px;height:28px;border:0;background:none;font-size:16px;cursor:pointer;color:var(--green-d,#26402f)}
.ci-qty span{min-width:28px;text-align:center;font-size:13px;font-weight:700}
.ci-rm{background:none;border:0;color:#b06a4a;font-size:12px;cursor:pointer;margin-top:8px;display:block}
.cart-ft{border-top:1px solid var(--line,#e8ddc9);padding:16px 20px;background:#fff}
.cart-line{display:flex;justify-content:space-between;font-size:13.5px;color:var(--sub,#7c6c58);margin-bottom:6px}
.cart-total{display:flex;justify-content:space-between;font-size:17px;font-weight:700;color:var(--green-d,#26402f);margin-top:8px}
.cart-go{width:100%;margin-top:14px;background:var(--rust,#c2683a);color:#fff;border:0;border-radius:8px;padding:14px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit}
.cart-go:hover{background:#a9572e}
.cart-go:disabled{opacity:.5;cursor:not-allowed}
.cart-note{font-size:11px;color:var(--sub,#7c6c58);text-align:center;margin-top:10px;line-height:1.6}

/* 定期便プロモ（ドロワー内） */
.sub-promo{margin-top:16px;border:1px dashed var(--rust,#c2683a);border-radius:12px;padding:14px 16px;background:#fdf6f1}
.sub-promo .sp-t{font-family:'Shippori Mincho',serif;font-size:14px;font-weight:700;color:var(--green-d,#26402f)}
.sub-promo .sp-d{font-size:12px;color:var(--sub,#7c6c58);margin:4px 0 10px;line-height:1.6}
.sub-promo .sp-btn{width:100%;background:#fff;color:var(--rust,#c2683a);border:1.5px solid var(--rust,#c2683a);border-radius:8px;padding:10px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:inherit}
.sub-promo .sp-btn:hover{background:var(--rust,#c2683a);color:#fff}

/* チェックアウト・モーダル */
.co-ov{position:fixed;inset:0;background:rgba(20,30,22,.5);opacity:0;visibility:hidden;transition:.25s;z-index:1100;display:flex;align-items:flex-start;justify-content:center;padding:24px;overflow-y:auto}
.co-ov.on{opacity:1;visibility:visible}
.co{background:var(--cream,#faf6ef);border-radius:16px;max-width:560px;width:100%;margin:auto;box-shadow:0 30px 70px rgba(0,0,0,.3);overflow:hidden}
.co-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;background:#fff;border-bottom:1px solid var(--line,#e8ddc9)}
.co-hd h3{font-family:'Shippori Mincho',serif;font-size:18px;color:var(--green-d,#26402f);margin:0}
.co-bd{padding:20px 22px}
.co-sec{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--rust,#c2683a);margin:18px 0 10px}
.co-sec:first-child{margin-top:0}
.co-field{margin-bottom:11px}
.co-field label{display:block;font-size:12px;color:var(--sub,#7c6c58);margin-bottom:4px}
.co-field input,.co-field select,.co-field textarea{width:100%;border:1px solid var(--line,#e8ddc9);border-radius:8px;padding:10px 12px;font-size:14px;font-family:inherit;background:#fff;color:var(--ink,#382c22)}
.co-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pay-opts{display:flex;flex-direction:column;gap:8px}
.pay-opt{display:flex;align-items:center;gap:10px;border:1.5px solid var(--line,#e8ddc9);border-radius:10px;padding:12px 14px;cursor:pointer;background:#fff}
.pay-opt.on{border-color:var(--rust,#c2683a);background:#fdf6f1}
.pay-opt input{accent-color:var(--rust,#c2683a)}
.pay-opt .t{font-size:14px;font-weight:700;color:var(--ink,#382c22)}
.pay-opt .d{font-size:11.5px;color:var(--sub,#7c6c58);margin-top:2px}
.co-sum{background:#fff;border:1px solid var(--line,#e8ddc9);border-radius:10px;padding:14px 16px;margin-top:6px}
.co-card{border:1px dashed var(--line,#e8ddc9);border-radius:10px;padding:14px;margin-top:10px;background:#fff}
.co-card .demo{font-size:11px;color:var(--rust,#c2683a);font-weight:700;margin-bottom:8px}
.co-done{text-align:center;padding:20px 6px}
.co-done .ic{font-size:46px}
.co-done h4{font-family:'Shippori Mincho',serif;font-size:20px;color:var(--green-d,#26402f);margin:10px 0 8px}
.co-done p{font-size:13.5px;color:var(--sub,#7c6c58);line-height:1.8}
.co-bank{background:#fff;border:1px solid var(--line,#e8ddc9);border-radius:10px;padding:14px 16px;margin-top:14px;text-align:left;font-size:13px;line-height:1.9}
.co-err{color:#b0392a;font-size:12.5px;margin-top:8px}

/* 確認用：支払いパターン切替バー */
.pay-mode{position:fixed;left:14px;bottom:14px;z-index:1200;background:#1d2b20;color:#fff;border-radius:12px;padding:10px 12px;box-shadow:0 10px 30px rgba(0,0,0,.25);font-size:12px;max-width:260px}
.pay-mode .lab{font-size:10.5px;opacity:.8;letter-spacing:.04em;margin-bottom:7px}
.pay-mode .opts{display:flex;gap:6px}
.pay-mode button{flex:1;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:7px 6px;font-size:11.5px;cursor:pointer;font-family:inherit;line-height:1.3}
.pay-mode button.on{background:var(--rust,#c2683a);border-color:var(--rust,#c2683a);font-weight:700}
.pay-mode .hide{position:absolute;top:6px;right:8px;background:none;border:0;color:rgba(255,255,255,.6);font-size:14px;cursor:pointer}
@media(max-width:560px){.pay-mode{left:8px;right:8px;bottom:8px;max-width:none}}
