/* ===== tool_shipping.css ===== */

/* ===== リセット・変数 ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fef9f4;--text:#5c4a3d;--muted:#b0a098;--ink:#3d2b1f;
  --pink:#e8a0b4;--pink-deep:#d4789a;--pink-pale:#fbeef2;--pink-soft:#f4d2dc;
  --divider:#ecdfd5;--card:#fff;
  --nav-bg:#1a1a2e;
}
body{font-family:'Zen Maru Gothic','Hiragino Sans','Noto Sans JP',sans-serif;background:var(--bg);color:var(--text);line-height:1.7;min-height:100vh}
a{color:inherit;text-decoration:none}

/* ===== ヘッダー（LP準拠） ===== */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(254,249,244,.9);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--divider);
}
.header-inner{
  max-width:1040px;margin:0 auto;padding:0 20px;
  display:flex;align-items:center;justify-content:space-between;
  height:56px;
}
.brand{display:flex;align-items:center;gap:9px}
.brand-mark{
  width:34px;height:34px;border-radius:10px;
  background:#1a1a2e;color:#e8a0b4;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.88rem;flex-shrink:0;
}
.brand-name{font-family:'Quicksand',sans-serif;font-weight:700;font-size:.95rem;letter-spacing:.01em;color:var(--ink)}
.header-actions{display:flex;align-items:center;gap:10px}
.header-login{font-size:.78rem;font-weight:600;color:var(--muted);padding:.38rem .7rem;border-radius:999px;transition:color .15s}
.header-login:hover{color:var(--pink-deep)}
.header-cta{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--pink-deep);color:#fff;
  padding:.42rem .9rem;border-radius:999px;
  font-size:.72rem;font-weight:700;
  transition:opacity .15s;
}
.header-cta:hover{opacity:.88}

/* ===== フッター（LP準拠） ===== */
.footer{background:#1a1a2e;color:rgba(255,255,255,.5);padding:32px 20px;text-align:center}
.footer-brand{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:.6rem}
.footer-brand-mark{width:28px;height:28px;border-radius:8px;background:#e8a0b4;display:flex;align-items:center;justify-content:center;color:#1a1a2e;font-weight:700;font-size:.75rem}
.footer-brand-name{font-family:'Quicksand',sans-serif;font-weight:700;font-size:.85rem;color:rgba(255,255,255,.8)}
.footer-text{font-size:.65rem;margin-bottom:.4rem}
.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1rem;margin-bottom:.6rem}
.footer-links a{font-size:.64rem;color:rgba(255,255,255,.4)}
.footer-links a:hover{color:rgba(255,255,255,.7)}
.footer-copy{font-size:.6rem;color:rgba(255,255,255,.25)}

/* ===== メイン ===== */
.tool-main{max-width:640px;margin:0 auto;padding:2rem 1rem 4rem}

/* ===== ヒーロー ===== */
.tool-hero{text-align:center;margin-bottom:2rem}
.tool-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--pink-deep);margin-bottom:.4rem}
.tool-title{font-size:clamp(1.5rem,5vw,2.2rem);font-weight:900;color:var(--ink);line-height:1.3;margin-bottom:.6rem}
.tool-desc{font-size:.9rem;color:var(--muted);max-width:480px;margin:0 auto}

/* ===== カード ===== */
.tool-card{background:var(--card);border:1.5px solid var(--pink-soft);border-radius:20px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 4px 20px rgba(92,74,61,.07)}

/* ===== ステッパー ===== */
.ts-steps{display:flex;align-items:center;margin-bottom:1.5rem}
.ts-step{display:flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:700;color:var(--muted);flex:1}
.ts-step-num{width:22px;height:22px;border-radius:50%;background:var(--divider);color:#fff;font-size:.68rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}
.ts-step.active .ts-step-num{background:var(--pink-deep)}
.ts-step.active{color:var(--ink)}
.ts-step.done .ts-step-num{background:#7ec8a4}
.ts-step.done{color:var(--muted)}
.ts-step-line{flex:1;height:2px;background:var(--divider);margin:0 .4rem;max-width:2rem}

/* ===== 販売元選択 ===== */
.ts-pf-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.ts-pf-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;
  padding:.9rem .6rem;border:2px solid var(--divider);border-radius:14px;background:var(--card);
  cursor:pointer;font-weight:700;font-size:.88rem;color:var(--ink);
  transition:border-color .15s,background .15s,box-shadow .15s;
  -webkit-tap-highlight-color:transparent;
}
.ts-pf-btn:hover{border-color:var(--pink);background:var(--pink-pale)}
.ts-pf-btn.selected{border-color:var(--pink-deep);background:var(--pink-pale);box-shadow:0 0 0 3px rgba(212,120,154,.15)}
.ts-pf-logo{height:32px;width:auto;max-width:100px;object-fit:contain;display:block}
.ts-pf-logo-sq{height:64px;width:64px;object-fit:contain}
.ts-pf-logo-base-wrap{height:32px;width:80px;background:#000;border-radius:6px;display:flex;align-items:center;justify-content:center;padding:0 8px}
.ts-pf-logo-base-wrap img{height:20px;width:auto;object-fit:contain}
.ts-pf-icon{font-size:1.5rem}
.ts-pf-name{font-size:.88rem;font-weight:700;color:var(--ink)}

/* ===== 入力 ===== */
.ts-dim-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.45rem}
.ts-field{display:flex;flex-direction:column;gap:.3rem}
.ts-label{font-size:.82rem;font-weight:700;color:var(--text)}
.ts-label-sub{font-size:.68rem;font-weight:400;color:var(--muted);margin-left:.3rem}
.ts-sublabel{font-size:.7rem;color:var(--muted)}
.ts-input{
  padding:.7rem .85rem;border:1.5px solid var(--divider);border-radius:10px;
  font-size:1rem;background:var(--bg);color:var(--ink);transition:border-color .15s;
  -webkit-appearance:none;width:100%;
}
.ts-input:focus{outline:none;border-color:var(--pink-deep);background:#fff}
.ts-form-stack{display:flex;flex-direction:column;gap:.9rem}

/* ===== ボタン ===== */
.ts-btn{
  display:block;width:100%;padding:.9rem;
  background:var(--pink-deep);color:#fff;border:none;border-radius:12px;
  font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .15s;margin-top:1.1rem;
}
.ts-btn:hover{opacity:.9}
.ts-btn:disabled{opacity:.35;cursor:default}
.ts-btn-back{
  display:inline-flex;align-items:center;gap:.3rem;background:none;border:none;
  color:var(--muted);font-size:.8rem;cursor:pointer;padding:0;margin-bottom:1.1rem;
}
.ts-btn-back:hover{color:var(--text)}

/* ===== 結果ヘッダー ===== */
.ts-result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}
.ts-result-title{font-size:.95rem;font-weight:700;color:var(--ink)}
.ts-pf-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.22rem .6rem;background:var(--pink-pale);border:1.5px solid var(--pink-soft);
  border-radius:20px;font-size:.75rem;font-weight:700;color:var(--pink-deep);
}

/* ===== サマリーカード ===== */
.ts-summary-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}
.ts-summary-card{
  background:var(--card);border:1.5px solid var(--divider);border-radius:14px;
  padding:.7rem 1rem;display:flex;align-items:center;gap:.75rem;
}
.ts-summary-card.best{border-color:var(--pink-deep);background:var(--pink-pale)}
.ts-summary-card.unavail{opacity:.4;background:var(--bg)}
.ts-summary-card-left{flex:1;min-width:0}
.ts-summary-label{font-size:.62rem;font-weight:700;color:var(--muted);letter-spacing:.04em;margin-bottom:.15rem}
.ts-summary-name{font-size:.82rem;font-weight:700;color:var(--ink);line-height:1.3}
.ts-summary-price{font-size:1.2rem;font-weight:900;color:var(--pink-deep);white-space:nowrap;flex-shrink:0}
.ts-summary-card.unavail .ts-summary-price{color:var(--muted);font-size:.82rem;font-weight:400}
.ts-best-tag{
  display:inline-block;font-size:.58rem;font-weight:700;
  background:var(--pink-deep);color:#fff;padding:.08rem .38rem;border-radius:8px;
  margin-left:.3rem;vertical-align:middle;
}

/* ===== 提携・専用箱バッジ ===== */
.ts-partner-tag{
  display:inline-block;font-size:.56rem;font-weight:700;
  background:#e8f5e9;color:#388e3c;border:1px solid #a5d6a7;
  padding:.06rem .36rem;border-radius:8px;margin-left:.3rem;vertical-align:middle;
}
.ts-box-tag{
  display:inline-block;font-size:.54rem;font-weight:700;
  background:#fff8e1;color:#f57c00;border:1px solid #ffe082;
  padding:.06rem .36rem;border-radius:8px;margin-left:.3rem;vertical-align:middle;
}

/* ===== 詳細アコーディオン ===== */
.ts-detail-toggle{
  display:flex;align-items:center;justify-content:center;gap:.4rem;
  width:100%;padding:.55rem;background:none;border:1.5px solid var(--divider);
  border-radius:10px;font-size:.78rem;font-weight:700;color:var(--pink-deep);
  cursor:pointer;margin:.5rem 0 0;transition:background .15s;
  -webkit-tap-highlight-color:transparent;
}
.ts-detail-toggle:hover{background:var(--pink-pale)}
.ts-detail-body{display:none;margin-top:.5rem}
.ts-detail-body.open{display:block}

.ts-section-label{font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:1rem 0 .4rem}

.ts-method-list{display:flex;flex-direction:column;gap:.4rem}
.ts-method-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:.65rem .85rem;background:var(--card);border:1.5px solid var(--divider);
  border-radius:11px;gap:.6rem;
}
.ts-method-item.best{border-color:var(--pink-deep);background:var(--pink-pale)}
.ts-method-item.na{opacity:.38;background:var(--bg);border-style:dashed}
.ts-method-left{flex:1;min-width:0}
.ts-method-name{font-size:.85rem;font-weight:700;color:var(--ink)}
.ts-method-note{font-size:.68rem;color:var(--muted);margin-top:.1rem}
.ts-method-price{font-size:1rem;font-weight:900;color:var(--pink-deep);white-space:nowrap;flex-shrink:0}
.ts-method-item.na .ts-method-price{color:var(--muted);font-size:.8rem;font-weight:400}

.ts-empty{text-align:center;padding:1.5rem .5rem;color:var(--muted);font-size:.88rem;line-height:1.9}
.ts-note{font-size:.7rem;color:var(--muted);line-height:1.7;margin-top:.75rem}

/* ===== 比較セレクター ===== */
.ts-compare-selector{
  display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap;
}
.ts-compare-selector-label{font-size:.78rem;font-weight:700;color:var(--text);white-space:nowrap}
.ts-compare-select{
  flex:1;min-width:120px;padding:.5rem .75rem;
  border:1.5px solid var(--divider);border-radius:10px;
  background:var(--bg);color:var(--ink);font-size:.85rem;font-weight:700;
  -webkit-appearance:none;appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23b0a098' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .7rem center;padding-right:2rem;
}
.ts-compare-select:focus{outline:none;border-color:var(--pink-deep)}

/* ===== 比較テーブル ===== */
.ts-compare-wrap{border-radius:12px;border:1.5px solid var(--divider)}
.ts-compare-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.82rem;min-width:280px}
.ts-compare-table th{
  background:#f5ede8;padding:.55rem .8rem;font-weight:700;font-size:.72rem;
  color:var(--text);border-bottom:2px solid var(--divider);text-align:center;
  position:sticky;top:56px;z-index:10;
}
.ts-compare-table th:first-child{text-align:left}
.ts-compare-table td{padding:.45rem .8rem;border-bottom:1px solid var(--divider);text-align:center;vertical-align:middle}
.ts-compare-table td:first-child{text-align:left;font-weight:600;color:var(--ink)}
.ts-compare-table tbody tr:last-child td{border-bottom:none}
.ts-compare-table tbody tr:hover{background:var(--pink-pale)}
.ts-cur-col{background:var(--pink-pale) !important;font-weight:700;color:var(--pink-deep) !important}
.ts-na-cell{color:var(--divider)}
.ts-cmp-section td{
  background:#f5ede8;font-size:.66rem;font-weight:700;letter-spacing:.06em;
  color:var(--muted);padding:.35rem .8rem;border-bottom:1.5px solid var(--divider);
  border-top:1.5px solid var(--divider);
}
.ts-cmp-cell{display:flex;flex-direction:column;align-items:center;gap:.15rem;line-height:1.2}
.ts-cmp-price{font-weight:700}
.ts-cmp-best{font-size:.56rem;font-weight:700;background:var(--pink-deep);color:#fff;padding:.05rem .35rem;border-radius:6px;white-space:nowrap}
.ts-cmp-partner{font-size:.54rem;font-weight:700;background:#e8f5e9;color:#388e3c;border:1px solid #a5d6a7;padding:.04rem .3rem;border-radius:5px;white-space:nowrap}

/* ===== CTAセクション（fee-calculator 準拠） ===== */
.ts-cta-section{
  background:linear-gradient(135deg,#1a1a2e,#2d1b5e);
  color:#fff;padding:3rem 1.5rem;text-align:center;
}
.ts-cta-inner{max-width:640px;margin:0 auto;}
.ts-cta-eyebrow{
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#b899e8;margin-bottom:.5rem;
}
.ts-cta-title{
  font-size:clamp(1.1rem,3vw,1.5rem);font-weight:900;line-height:1.4;margin-bottom:1.5rem;
}
.ts-cta-img{
  width:100%;max-width:520px;border-radius:10px;
  margin-bottom:1.5rem;box-shadow:0 4px 24px rgba(0,0,0,.3);cursor:zoom-in;
}
.ts-cta-features{
  display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.75rem;
}
.ts-cta-feat{
  display:flex;align-items:center;gap:.4rem;font-size:.88rem;color:#c8b8e8;
}
.ts-cta-btn{
  display:inline-block;padding:.9rem 2.5rem;
  background:linear-gradient(135deg,#e8668c,#c84b7a);
  color:#fff;border-radius:10px;font-size:1.05rem;font-weight:700;transition:opacity .15s;
}
.ts-cta-btn:hover{opacity:.9;}
.ts-cta-note{font-size:.78rem;color:#9988cc;margin-top:.75rem;}
.ts-lightbox{
  position:fixed;inset:0;background:rgba(0,0,0,.8);
  display:flex;align-items:center;justify-content:center;z-index:9999;cursor:zoom-out;
}
.ts-lightbox-img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5);}

/* ===== パネル ===== */
.ts-panel{display:none}
.ts-panel.active{display:block}

