/* ============================================================
   配送順 簡易最適化 — style.css
   LPデザイントークン使用。フォントはセルフホスト（外部CDN不使用）。
   ============================================================ */

/* ---------- フォント（セルフホスト / オフライン動作） ---------- */
@font-face{font-family:'Shippori Mincho';font-style:normal;font-weight:700;font-display:swap;
  src:url('fonts/shippori-mincho-latin-700.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Shippori Mincho';font-style:normal;font-weight:700;font-display:swap;
  src:url('fonts/shippori-mincho-japanese-700.woff2') format('woff2');
  unicode-range:U+3000-303F, U+3040-309F, U+30A0-30FF, U+FF00-FFEF, U+4E00-9FFF, U+3400-4DBF;}
@font-face{font-family:'Zen Kaku Gothic New';font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/zen-kaku-gothic-new-latin-400.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Zen Kaku Gothic New';font-style:normal;font-weight:400;font-display:swap;
  src:url('fonts/zen-kaku-gothic-new-japanese-400.woff2') format('woff2');
  unicode-range:U+3000-303F, U+3040-309F, U+30A0-30FF, U+FF00-FFEF, U+4E00-9FFF, U+3400-4DBF;}
@font-face{font-family:'Zen Kaku Gothic New';font-style:normal;font-weight:700;font-display:swap;
  src:url('fonts/zen-kaku-gothic-new-latin-700.woff2') format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Zen Kaku Gothic New';font-style:normal;font-weight:700;font-display:swap;
  src:url('fonts/zen-kaku-gothic-new-japanese-700.woff2') format('woff2');
  unicode-range:U+3000-303F, U+3040-309F, U+30A0-30FF, U+FF00-FFEF, U+4E00-9FFF, U+3400-4DBF;}

:root{
  --navy:#0f2540; --navy-2:#163056; --gold:#c9a449; --gold-soft:#fbf4df;
  --paper:#f7f5f0; --ink:#1a1f28; --gray:#5a6677; --line:#dcd6c9; --white:#fff;
  --radius:6px; --shadow:0 1px 3px rgba(15,37,64,.08), 0 6px 18px rgba(15,37,64,.06);
  --font-head:'Shippori Mincho',"Yu Mincho","游明朝",serif;
  --font-body:'Zen Kaku Gothic New',"Hiragino Kaku Gothic ProN","Meiryo",sans-serif;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.7;-webkit-font-smoothing:antialiased;}

/* ヘッダー */
.site-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:14px 24px;background:var(--navy);color:var(--white);}
.brand{display:flex;align-items:center;gap:14px;}
.brand-logo{font-weight:700;letter-spacing:.12em;font-size:1.05rem;}
.brand-divider{width:1px;height:20px;background:var(--gold);display:inline-block;}
.brand-tool{font-family:var(--font-head);font-weight:700;font-size:1.1rem;margin:0;}
.back-link{color:var(--white);text-decoration:none;font-size:.9rem;opacity:.9;border-bottom:1px solid transparent;transition:border-color .15s,opacity .15s;}
.back-link:hover{opacity:1;border-bottom-color:var(--gold);}

/* レイアウト */
.layout{max-width:1180px;margin:24px auto;padding:0 20px;display:grid;grid-template-columns:1fr minmax(300px,360px);gap:22px;align-items:start;}
@media (max-width:880px){ .layout{grid-template-columns:1fr;} }
.panel{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;}
.section-label{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--navy);margin:0 0 10px;padding-left:12px;position:relative;}
.section-label::before{content:"";position:absolute;left:0;top:.15em;bottom:.15em;width:3px;background:var(--gold);border-radius:2px;}
.tool-lead{font-size:.9rem;color:var(--gray);margin:0 0 12px;}
.tool-lead strong{color:var(--ink);}

/* マップ */
.map-wrap{width:100%;}
#map{display:block;width:100%;border:1px solid var(--line);border-radius:var(--radius);cursor:crosshair;touch-action:none;}
.hint{font-size:.82rem;color:var(--gray);margin:8px 0 0;min-height:1.1em;}

/* コントロール */
.controls{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:12px 0 4px;}
.btn{font-family:inherit;font-size:.9rem;font-weight:700;padding:9px 16px;border-radius:var(--radius);border:1px solid var(--navy);background:#fff;color:var(--navy);cursor:pointer;transition:background .12s,color .12s;}
.btn:hover{background:var(--paper);}
.btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.btn-primary{background:var(--navy);color:var(--white);}
.btn-primary:hover{background:var(--navy-2);}
.btn-ghost{border-color:var(--line);color:var(--gray);}
.btn-ghost:hover{background:var(--paper);color:var(--ink);}
.btn-sm{padding:7px 12px;font-size:.84rem;}
.check{display:flex;align-items:center;gap:7px;font-size:.86rem;cursor:pointer;color:var(--gray);}
.check input{width:16px;height:16px;accent-color:var(--navy);}

/* ビュー切替（セグメント） */
.seg-group{display:inline-flex;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
.seg{font-family:inherit;font-size:.82rem;font-weight:700;padding:8px 14px;background:#fff;color:var(--gray);cursor:pointer;border:0;border-right:1px solid var(--line);}
.seg:last-child{border-right:0;}
.seg.is-active{background:var(--navy);color:#fff;}

/* 結果 */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:6px 0 14px;}
.stat{border:1px solid var(--line);border-radius:var(--radius);background:var(--paper);padding:12px;text-align:center;}
.stat-v{font-family:var(--font-head);font-weight:700;font-size:1.35rem;color:var(--navy);line-height:1.15;}
.stat-v.accent{color:#7a5b00;}
.stat-v.good{color:#2f7d4f;}
.stat-l{font-size:.74rem;color:var(--gray);margin-top:3px;}

.seq-label{font-size:.78rem;color:var(--gray);margin-bottom:6px;}
.seq-row{display:flex;flex-wrap:wrap;align-items:center;gap:4px;}
.chip{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:26px;padding:0 7px;border-radius:13px;background:#fff;border:1.5px solid var(--gold);color:var(--navy);font-weight:700;font-size:.82rem;}
.chip.depot{background:var(--navy);border-color:var(--navy);color:#fff;}
.arrow{color:var(--gray);font-size:.8rem;}

.export-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;}

.privacy-note{font-size:.8rem;color:var(--gray);margin:14px 0 0;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:9px 12px;}
.privacy-note strong{color:var(--ink);}

/* フッター */
.site-footer{max-width:1180px;margin:8px auto 28px;padding:16px 20px 0;border-top:1px solid var(--line);color:var(--gray);font-size:.82rem;text-align:center;}
.site-footer p{margin:4px 0;}
