/* ============================================================
 * 嶺北9市町ぴったり住み分け見える化ボード - style.css
 * Design: ポップ（9市町キーカラー × ホワイト × 太字サンセリフ）
 * ============================================================ */

:root{
  --c-fukui:        #EF4060;
  --c-sakai:        #F5A524;
  --c-awara:        #22B8CF;
  --c-ono:          #7048E8;
  --c-katsuyama:    #FA5252;
  --c-sabae:        #12B886;
  --c-echizen_city: #1971C2;
  --c-eiheiji:      #82C91E;
  --c-ikeda:        #E64980;

  --pink: #EF4060;
  --yellow: #F5A524;
  --teal: #22B8CF;
  --green: #12B886;
  --blue: #1971C2;
  --purple: #7048E8;
  --magenta: #E64980;

  --bg: #FFF9F2;
  --bg-2: #FFFFFF;
  --ink: #1A1A1A;
  --ink-2: #4A4A4A;
  --line: #F0E5D8;

  --shadow-soft: 0 4px 14px rgba(20,10,0,.06);
  --shadow-pop: 0 8px 28px rgba(239,64,96,.18);
}

*{ box-sizing:border-box; }

html, body {
  margin:0; padding:0;
  background: var(--bg);
  color: var(--ink);
  font-family:"Zen Maru Gothic","Noto Sans JP","Hiragino Sans",sans-serif;
  font-weight:500;
  line-height:1.65;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
}

a { color: var(--blue); }

/* ===== 戻るリンク（左上固定） ===== */
.back-link{
  position:fixed; top:14px; left:14px; z-index:9999;
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 14px;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:999px;
  font-family:"Zen Maru Gothic",sans-serif;
  font-weight:900;
  font-size:14px;
  color:var(--ink);
  text-decoration:none;
  box-shadow: 4px 4px 0 var(--ink);
  transition:transform .15s;
}
.back-link:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
@media (max-width:480px){
  .back-link{ font-size:12px; padding:6px 10px; }
}

/* ===== ヘッダー ===== */
.app-header{
  position:relative;
  padding:90px 24px 40px;
  text-align:center;
  background: linear-gradient(135deg, #FFF7E6 0%, #FFE9F0 50%, #E6F4FF 100%);
  border-bottom:6px solid var(--ink);
  overflow:hidden;
}
.header-pattern{
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 12% 28%, rgba(239,64,96,.18) 0 22px, transparent 23px),
    radial-gradient(circle at 78% 18%, rgba(245,165,36,.16) 0 28px, transparent 29px),
    radial-gradient(circle at 88% 78%, rgba(34,184,207,.16) 0 24px, transparent 25px),
    radial-gradient(circle at 22% 82%, rgba(112,72,232,.13) 0 20px, transparent 21px),
    radial-gradient(circle at 50% 50%, rgba(18,184,134,.10) 0 16px, transparent 17px);
  pointer-events:none;
}
.header-inner{ position:relative; z-index:1; max-width:1080px; margin:0 auto; }
.badge-row{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:18px;
}
.badge{
  display:inline-block; padding:6px 14px; border-radius:999px;
  font-family:"Reggae One","Mochiy Pop One",sans-serif;
  font-size:13px; letter-spacing:.1em;
  border:3px solid var(--ink);
  box-shadow:3px 3px 0 var(--ink);
  background:#fff;
}
.badge-pink{ background:#FFE3EA; color:var(--pink); }
.badge-yellow{ background:#FFF1D6; color:#B45309; }
.badge-green{ background:#E0FBF1; color:var(--green); }

.app-header h1{
  font-family:"Mochiy Pop One","Reggae One",sans-serif;
  font-size:clamp(32px, 5.4vw, 60px);
  line-height:1.18;
  margin:0 0 14px;
  letter-spacing:.02em;
  color:var(--ink);
}
.app-header h1 .hl{
  background: linear-gradient(transparent 60%, #FFE066 60%);
  padding:0 4px;
}
.subtitle{
  font-family:"Reggae One",sans-serif;
  font-size:14px;
  letter-spacing:.18em;
  color:var(--ink-2);
  margin:0 0 14px;
}
.tagline{
  font-size:16px; max-width:760px; margin:0 auto 26px; color:var(--ink-2);
}
.header-stats{
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
  list-style:none; padding:0; margin:0;
}
.header-stats li{
  background:#fff;
  border:3px solid var(--ink);
  box-shadow:4px 4px 0 var(--ink);
  border-radius:18px;
  padding:10px 16px;
  min-width:96px;
  text-align:center;
}
.header-stats b{
  display:block;
  font-family:"Mochiy Pop One",sans-serif;
  font-size:24px; line-height:1.1;
  color:var(--pink);
}
.header-stats span{
  font-size:11px; letter-spacing:.1em; color:var(--ink-2);
}

/* ===== ステッパー ===== */
.stepper{
  position:sticky; top:0; z-index:10;
  display:flex; gap:8px; flex-wrap:wrap;
  justify-content:center;
  padding:12px;
  background:#fff;
  border-bottom:4px solid var(--ink);
}
.step-chip{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:999px;
  font-family:"Zen Maru Gothic",sans-serif;
  font-weight:900; font-size:13px;
  cursor:pointer;
  box-shadow:3px 3px 0 var(--ink);
  transition:transform .15s;
  color:var(--ink);
}
.step-chip:hover{ transform:translate(-1px,-1px); box-shadow:4px 4px 0 var(--ink); }
.step-chip .num{
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; border-radius:50%;
  background:#FFE3EA; color:var(--pink); font-size:13px;
}
.step-chip.active{ background:var(--pink); color:#fff; }
.step-chip.active .num{ background:#fff; color:var(--pink); }
.step-chip.done{ background:#E0FBF1; }
.step-chip.done .num{ background:var(--green); color:#fff; }
.step-chip.disabled{ opacity:.5; cursor:not-allowed; }

/* ===== Main ===== */
.app-main{ max-width:1180px; margin:0 auto; padding:30px 18px 60px; }
.screen{ display:none; animation:fadeIn .35s ease; }
.screen.active{ display:block; }
@keyframes fadeIn{ from{ opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);}}

.panel{
  background:#fff;
  border:4px solid var(--ink);
  border-radius:24px;
  box-shadow:6px 6px 0 var(--ink);
  padding:30px;
}
.pop-panel{
  position:relative;
  background:
    radial-gradient(circle at top right, rgba(245,165,36,.08), transparent 250px),
    radial-gradient(circle at bottom left, rgba(34,184,207,.08), transparent 280px),
    #fff;
}
.panel h2{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:clamp(22px, 3.2vw, 30px);
  margin:0 0 6px;
}
.h2-num{
  display:inline-block;
  background:var(--pink);
  color:#fff;
  border-radius:999px;
  padding:0 14px;
  margin-right:8px;
  font-size:.8em;
}
.h2-ruby{
  display:block;
  font-family:"Reggae One",sans-serif;
  font-size:12px; letter-spacing:.18em;
  color:var(--ink-2);
  margin-bottom:18px;
}
.lead{ margin:0 0 22px; color:var(--ink-2); font-size:15px; }

/* ===== Form fields ===== */
.field{ margin:18px 0; }
.big-label{
  display:flex; align-items:center; gap:10px;
  font-family:"Zen Maru Gothic",sans-serif;
  font-weight:900; font-size:17px;
  margin-bottom:10px;
}
.dot{
  width:14px; height:14px; border-radius:50%;
  border:2px solid var(--ink);
}
.dot-pink{ background:var(--pink); }
.dot-yellow{ background:var(--yellow); }
.dot-blue{ background:var(--blue); }

.chip-row{
  display:flex; flex-wrap:wrap; gap:8px;
}
.chip{
  display:inline-block;
  padding:9px 16px;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:999px;
  font-family:"Zen Maru Gothic",sans-serif;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  box-shadow:3px 3px 0 var(--ink);
  transition: transform .12s, background .12s;
  color:var(--ink);
}
.chip:hover{ transform:translate(-1px,-1px); background:#FFF6E5; }
.chip.active{ background:var(--ink); color:#fff; box-shadow:3px 3px 0 var(--pink); }

.dotted{ border:none; border-top:3px dotted var(--line); margin:30px 0 24px; }
.sub-h{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:18px;
  margin:0 0 16px;
}

/* ===== Q4-Q20 ===== */
.qq-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:14px;
}
.qq-card{
  border:3px solid var(--ink);
  border-radius:18px;
  padding:14px;
  background:#fff;
  box-shadow:3px 3px 0 var(--ink);
}
.qq-text{ font-weight:700; margin-bottom:10px; font-size:14px; }
.qq-opts{ display:flex; flex-wrap:wrap; gap:6px; }
.qq-opt{
  border:2px solid var(--ink);
  border-radius:999px;
  background:#fff;
  font-family:"Zen Maru Gothic",sans-serif;
  font-weight:700;
  padding:5px 12px;
  font-size:12px;
  cursor:pointer;
  color:var(--ink);
}
.qq-opt:hover{ background:#FFF6E5; }
.qq-opt.active{ background:var(--blue); color:#fff; border-color:var(--ink); }

.btn-row{
  display:flex; justify-content:space-between; gap:12px;
  margin-top:30px; flex-wrap:wrap;
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 26px;
  font-family:"Mochiy Pop One",sans-serif;
  font-size:16px;
  border:3px solid var(--ink);
  border-radius:999px;
  background:#fff;
  cursor:pointer;
  color:var(--ink);
  box-shadow:4px 4px 0 var(--ink);
  transition:transform .12s;
}
.btn:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.btn:disabled{ opacity:.6; cursor:wait; }
.btn-primary{ background:var(--pink); color:#fff; }
.btn-yellow{ background:var(--yellow); color:#fff; }
.btn-pink{ background:#FFE3EA; }
.btn-ghost{ background:#fff; }
.btn.big{ font-size:18px; padding:16px 32px; }
.btn.btn-small{ font-size:13px; padding:7px 14px; box-shadow:3px 3px 0 var(--ink); }

/* ===== Step 2: Weights ===== */
.weights-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:14px;
  margin-bottom:30px;
}
.w-card{
  border:3px solid var(--ink);
  border-radius:18px;
  padding:14px;
  background:#fff;
  box-shadow:3px 3px 0 var(--ink);
}
.w-head{ display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.w-icon{ font-size:22px; }
.w-label{ font-family:"Mochiy Pop One",sans-serif; font-size:18px; }
.w-val{
  margin-left:auto;
  background:var(--pink); color:#fff;
  padding:2px 12px;
  border-radius:999px;
  font-family:"Mochiy Pop One",sans-serif;
}
.w-range{
  width:100%;
  -webkit-appearance:none; appearance:none;
  height:8px; border-radius:6px;
  background: linear-gradient(to right, var(--yellow), var(--pink));
  outline:none;
}
.w-range::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:24px; height:24px;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:50%;
  cursor:pointer;
  box-shadow:2px 2px 0 var(--ink);
}
.w-desc{ font-size:12px; color:var(--ink-2); margin-top:6px; }

.weights-radar-wrap{ text-align:center; }
.weights-radar-wrap canvas{ max-width:100%; height:auto; }

/* ===== Step 3: ranking ===== */
.ranking-bar{ display:flex; flex-direction:column; gap:8px; margin-bottom:30px; }
.rank-row{
  display:grid;
  grid-template-columns: 50px 200px 1fr;
  gap:12px;
  align-items:center;
  padding:10px 14px;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:14px;
  box-shadow:3px 3px 0 var(--ink);
}
.rank-row.top{
  background: #FFF6E5;
  border-color: var(--accent);
}
.rank-pos{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:24px;
  text-align:center;
  color:var(--accent);
}
.rank-name b{ display:block; font-size:16px; }
.rank-tag{ font-size:11px; color:var(--ink-2); }
.rank-bar-wrap{
  position:relative;
  background:#F5EFE3;
  height:24px;
  border-radius:999px;
  overflow:hidden;
  border:2px solid var(--ink);
}
.rank-bar{
  position:absolute; top:0; left:0; bottom:0;
  background:var(--accent);
  transition:width .9s cubic-bezier(.2,.8,.3,1.1);
}
.rank-score{
  position:relative;
  font-family:"Mochiy Pop One",sans-serif;
  font-size:14px;
  padding-left:10px;
  line-height:24px;
  color:var(--ink);
  z-index:1;
}

/* ===== Step 3: compare grid ===== */
.compare-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:24px;
  margin:30px 0;
}
@media (max-width:780px){ .compare-grid{ grid-template-columns:1fr; } }
.compare-radar canvas{ max-width:100%; height:auto; }
.legend-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; justify-content:center; }
.lg-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px;
  border:2px solid var(--c, var(--ink));
  border-radius:999px;
  font-size:13px; font-weight:700;
  background:#fff;
}
.lg-chip i.lg-dot{
  width:10px; height:10px; border-radius:50%; background:var(--c, var(--ink));
}
.compare-axis .axis-best-list{
  list-style:none; padding:0; margin:0;
}
.axis-best-list li{
  display:flex; align-items:center; gap:8px;
  padding:8px 12px;
  margin-bottom:6px;
  border:3px solid var(--ink);
  border-radius:14px;
  background:#fff;
  box-shadow:2px 2px 0 var(--ink);
}
.ab-icon{ font-size:18px; }
.ab-label{ font-weight:700; min-width:88px; }
.ab-best{
  flex:1;
  color:#fff;
  padding:3px 10px;
  border-radius:999px;
  font-weight:900;
  text-align:center;
  font-size:13px;
}
.ab-val{ font-family:"Mochiy Pop One",sans-serif; }

/* ===== Matrix table ===== */
.matrix-wrap, .rent-wrap, .edu-table, .hosp-table, .comm-table{
  overflow-x:auto; margin-bottom:24px;
}
.matrix-table, .rent-table, .edu-table, .hosp-table, .comm-table{
  width:100%; min-width:700px;
  border-collapse:separate; border-spacing:0;
  font-family:"Zen Maru Gothic",sans-serif;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:14px;
  overflow:hidden;
  box-shadow:3px 3px 0 var(--ink);
}
.matrix-table thead th, .rent-table thead th, .edu-table thead th, .hosp-table thead th, .comm-table thead th{
  background:var(--ink);
  color:#fff;
  font-family:"Mochiy Pop One",sans-serif;
  padding:10px 8px;
  font-size:12px;
  text-align:center;
}
.matrix-table tbody tr, .rent-table tbody tr, .edu-table tbody tr, .hosp-table tbody tr, .comm-table tbody tr{
  border-top:1px dashed var(--line);
}
.matrix-table .cell, .rent-table td, .edu-table td, .hosp-table td, .comm-table td{
  padding:10px 8px;
  text-align:center;
  font-weight:700;
}
.cell-total{
  background:#FFE066;
  font-family:"Mochiy Pop One",sans-serif;
  text-align:center;
  padding:10px;
}
.city-th{
  text-align:left;
  padding:10px 12px;
  background:#fff;
  font-size:13px;
}
.is-top{ background: #FFFBE6; }

/* ===== Step 4: Map ===== */
.map-wrap{
  margin:20px 0 30px;
  border:4px solid var(--ink);
  border-radius:18px;
  overflow:hidden;
  box-shadow:5px 5px 0 var(--ink);
}
#map{ width:100%; height:520px; }
.map-legend{
  display:flex; flex-wrap:wrap; gap:8px;
  padding:10px 14px;
  background:#FFF6E5;
  border-top:3px dashed var(--ink);
}
.map-lg-chip{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px; font-weight:700;
}
.map-lg-chip i{
  width:14px; height:14px; border-radius:50%;
  background:var(--c, var(--ink));
  border:2px solid var(--ink);
}
.map-lg-divider{
  width:2px; background:var(--ink); margin:0 6px;
}
.map-lg-icon{
  display:inline-flex; align-items:center; gap:4px; font-size:12px;
}
.map-lg-icon b{
  display:inline-flex; align-items:center; justify-content:center;
  width:22px; height:22px; border-radius:50%;
  background:var(--ink); color:#fff;
  font-size:11px;
}
.poi-icon span{
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:50%;
  border:3px solid #fff;
  color:#fff; font-weight:900;
  box-shadow: 0 2px 6px rgba(0,0,0,.3);
  font-size:12px;
}

/* ===== City cards ===== */
.city-cards{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:18px; margin-bottom:30px;
}
.city-card{
  background:#fff;
  border:4px solid var(--c);
  border-radius:20px;
  padding:18px;
  position:relative;
  box-shadow:5px 5px 0 var(--ink);
}
.city-card header{ border-bottom:3px dashed #F0E5D8; padding-bottom:10px; margin-bottom:10px; }
.cc-rank{
  position:absolute; top:-14px; left:14px;
  background:var(--c); color:#fff;
  padding:3px 14px; border-radius:999px;
  font-family:"Mochiy Pop One",sans-serif;
  border:3px solid var(--ink);
}
.city-card h3{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:24px; margin:8px 0 4px;
  display:flex; flex-wrap:wrap; align-items:baseline; gap:8px;
}
.cc-en{
  font-family:"Reggae One",sans-serif; font-size:11px;
  color:var(--ink-2); letter-spacing:.18em;
}
.cc-theme{ font-size:12px; color:var(--ink-2); margin:0; }
.cc-score{
  font-family:"Mochiy Pop One",sans-serif;
  background:#FFF6E5;
  border:2px solid var(--ink);
  border-radius:12px;
  padding:8px 12px;
  margin:10px 0;
  text-align:center;
}
.cc-score b{ font-size:28px; color:var(--c); }
.cc-score span{ font-size:11px; color:var(--ink-2); margin-left:4px; }
.cc-blurb{ font-size:13px; color:var(--ink-2); line-height:1.7; }
.cc-tags{ display:flex; flex-wrap:wrap; gap:5px; margin:10px 0; }
.cc-tag{
  background:#FFF6E5;
  border:2px solid var(--ink);
  padding:2px 9px; border-radius:999px;
  font-size:11px; font-weight:700;
}
.cc-axis-list{ list-style:none; padding:0; margin:0; }
.cc-axis-list li{
  display:grid;
  grid-template-columns: 24px 90px 1fr 36px;
  align-items:center; gap:6px;
  font-size:12px; padding:3px 0;
}
.cca-bar{
  background:#F5EFE3; height:8px; border-radius:999px; overflow:hidden;
  border:1px solid var(--ink);
}
.cca-bar i{ display:block; height:100%; }
.cca-val{ text-align:right; font-family:"Mochiy Pop One",sans-serif; }

/* ===== Step 5: Mail cards ===== */
.report-actions{
  display:flex; gap:14px; flex-wrap:wrap; margin-bottom:24px;
}
.mail-cards{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap:14px;
}
.mail-card{
  border:4px solid var(--c, var(--ink));
  border-radius:18px;
  background:#fff;
  padding:14px;
  box-shadow:5px 5px 0 var(--ink);
}
.mc-head{
  display:flex; flex-wrap:wrap; align-items:baseline; gap:8px;
  margin-bottom:8px;
  border-bottom:3px dashed #F0E5D8;
  padding-bottom:8px;
}
.mc-head b{ font-family:"Mochiy Pop One",sans-serif; font-size:18px; color:var(--c, var(--ink)); }
.mc-head span{ font-size:12px; color:var(--ink-2); }
.mc-body{
  background:#FFF6E5;
  border:2px solid var(--ink);
  border-radius:10px;
  padding:10px;
  font-size:11.5px;
  font-family:"Zen Maru Gothic",sans-serif;
  white-space:pre-wrap;
  max-height:240px; overflow-y:auto;
  margin:0 0 10px;
}
.mc-actions{ display:flex; gap:8px; flex-wrap:wrap; }

/* ===== PDF preview ===== */
.report-preview-wrap{ margin-top:30px; }
.report-preview{
  display:flex; flex-direction:column; gap:18px;
}
.pdf-page{
  width:100%; max-width:760px;
  margin:0 auto;
  background:#fff;
  border:3px solid var(--ink);
  border-radius:8px;
  padding:30px;
  box-shadow:4px 4px 0 var(--ink);
  min-height:500px;
  font-family:"Zen Maru Gothic",sans-serif;
  font-size:13px;
}
.pdf-cover{
  position:relative;
  min-height:600px;
  display:flex; flex-direction:column; justify-content:center;
  background:linear-gradient(135deg,#FFF7E6 0%,#FFE9F0 50%,#E6F4FF 100%);
  border-radius:6px;
  padding:30px;
  overflow:hidden;
}
.pdf-cover-pattern{
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(239,64,96,.18) 0 18px, transparent 19px),
    radial-gradient(circle at 80% 20%, rgba(245,165,36,.16) 0 24px, transparent 25px),
    radial-gradient(circle at 85% 80%, rgba(34,184,207,.16) 0 20px, transparent 21px),
    radial-gradient(circle at 25% 80%, rgba(112,72,232,.13) 0 18px, transparent 19px);
}
.pdf-cover-inner{ position:relative; z-index:1; }
.pdf-kicker{
  font-family:"Reggae One",sans-serif;
  font-size:12px;
  letter-spacing:.18em;
  color:var(--ink-2);
}
.pdf-cover h1{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:32px;
  margin:8px 0;
}
.pdf-sub{
  font-size:13px; color:var(--ink-2); margin-bottom:20px;
}
.pdf-summary{
  background:#fff; padding:14px; border-radius:10px; border:2px solid var(--ink);
  margin-bottom:18px;
  display:grid; grid-template-columns: repeat(2,1fr); gap:6px;
}
.pdf-summary p{ margin:0; font-size:12px; }
.pdf-top3{
  display:flex; gap:8px; flex-wrap:wrap;
}
.pdf-top3-item{
  flex:1 1 30%;
  background:#fff;
  border:3px solid var(--c);
  border-radius:14px;
  padding:8px;
  text-align:center;
}
.pdf-top3-item span{
  font-family:"Mochiy Pop One",sans-serif;
  background:var(--c); color:#fff;
  border-radius:999px;
  padding:1px 10px;
  font-size:11px;
}
.pdf-top3-item b{
  display:block; font-family:"Mochiy Pop One",sans-serif; font-size:18px;
  margin:4px 0;
}
.pdf-top3-item i{
  font-style:normal;
  font-family:"Mochiy Pop One",sans-serif;
  color:var(--c);
}

.pdf-page h2{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:22px; margin:0 0 16px;
  border-bottom:3px solid var(--pink);
  padding-bottom:8px;
}
.pdf-page h3{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:16px;
  margin:18px 0 10px;
  color:var(--blue);
}
.pdf-page h4{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:13px;
  margin:10px 0 4px;
  color:var(--pink);
}
.pdf-axes{
  display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin-bottom:18px;
}
.pdf-axis{
  background:#FFF6E5;
  border:2px solid var(--ink);
  border-radius:10px;
  padding:6px; text-align:center;
}
.pdf-axis span{ font-size:18px; }
.pdf-axis b{ display:block; font-size:11px; }
.pdf-axis i{ font-style:normal; font-family:"Mochiy Pop One",sans-serif; color:var(--pink); }
.pdf-rank-row{
  display:grid;
  grid-template-columns: 30px 1fr 50px;
  align-items:center;
  border-bottom:1px dashed var(--line);
  padding:4px 0;
  font-size:13px;
}
.pdf-rank-row b{ font-family:"Mochiy Pop One",sans-serif; }
.pdf-rank-row i{ font-style:normal; font-family:"Mochiy Pop One",sans-serif; text-align:right; }

.pdf-city{
  border:3px solid var(--c);
  border-radius:14px;
  padding:14px;
  background:#fff;
}
.pdf-city-head{
  display:flex; justify-content:space-between; align-items:center;
  border-bottom:2px dashed #F0E5D8;
  padding-bottom:8px; margin-bottom:8px;
}
.pdf-city-head b{
  font-family:"Mochiy Pop One",sans-serif;
  font-size:20px;
  color:var(--c);
}
.pdf-city-head span{ font-size:12px; color:var(--ink-2); }
.pdf-blurb{ font-size:12px; color:var(--ink-2); line-height:1.7; }
.pdf-city p{ margin:0 0 6px; font-size:12px; }

.pdf-matrix, .pdf-rent{
  width:100%; border-collapse:collapse; font-size:11px;
  margin-bottom:14px;
}
.pdf-matrix th, .pdf-matrix td, .pdf-rent th, .pdf-rent td{
  border:1px solid var(--line);
  padding:4px 5px;
  text-align:center;
}
.pdf-matrix thead th, .pdf-rent thead th{
  background:var(--ink); color:#fff;
  font-family:"Mochiy Pop One",sans-serif;
  font-size:10.5px;
}
.pdf-foot{ font-size:10px; color:var(--ink-2); margin-top:14px; text-align:center; }

/* ===== Footer ===== */
.app-foot{
  background:var(--ink);
  color:#fff;
  text-align:center;
  padding:24px 14px 28px;
  margin-top:30px;
}
.app-foot p{ margin:4px 0; font-size:13px; }
.app-foot p.tiny{ font-size:11px; opacity:.7; }

/* ===== Responsive ===== */
@media (max-width:720px){
  .panel{ padding:18px; border-radius:18px; }
  .stepper{ padding:8px; gap:6px; }
  .step-chip{ font-size:11px; padding:6px 10px; }
  .qq-grid{ grid-template-columns:1fr; }
  .rank-row{ grid-template-columns: 40px 1fr; }
  .rank-row .rank-bar-wrap{ grid-column:1/-1; }
  .pdf-axes{ grid-template-columns:repeat(2,1fr); }
  .pdf-summary{ grid-template-columns:1fr; }
  .header-stats li{ min-width:78px; padding:8px 10px; }
  .header-stats b{ font-size:18px; }
  .pdf-page{ padding:18px; }
  .pdf-cover{ min-height:420px; padding:18px; }
  .pdf-cover h1{ font-size:24px; }
  #map{ height:400px; }
}
