/* =============================================================
   物件比較ダッシュボード — Refined
   モダン・ニュートラル × 沿線色をデータ色として活かす
   ============================================================= */

:root{
  /* === Neutral base (Light theme) === */
  --bg:#f6f6f4;            /* page bg — warm off-white */
  --surface:#ffffff;       /* cards, table */
  --surface-2:#fafaf8;     /* toolbar, footer */
  --ink:#0e1116;           /* primary text */
  --ink-2:#3a414b;         /* secondary text */
  --muted:#7a818d;         /* tertiary */
  --muted-2:#aab0ba;
  --border:#e7e6e1;        /* hairlines */
  --border-2:#dedcd5;
  --soft:#efeee9;          /* hover, scale rail */
  --hover:#f3f2ee;

  /* === Accent === */
  --accent:#2c6e3a;        /* forest */
  --accent-2:#1f522a;      /* hover */
  --accent-soft:#dfeee2;   /* light backdrop */
  --accent-ink:#ffffff;    /* text on accent */

  /* === Line colors (always visible) === */
  --keio:#8b3fcf;          /* 京王 紫 */
  --odakyu:#1e63d6;        /* 小田急 青 */
  --tokyu:#dc5a14;         /* 東急 橙 */
  --keio-soft:#f4ebfa;
  --odakyu-soft:#e8f0fc;
  --tokyu-soft:#fbeadf;

  /* === Semantic === */
  --good:#1a7f4f;
  --bad:#b3261e;

  /* === Type === */
  --font-sans: "Inter","Noto Sans JP","Hiragino Sans","Yu Gothic UI",system-ui,sans-serif;
  --font-num: "Inter","Noto Sans JP",system-ui,sans-serif;
  --font-jp: "Noto Sans JP","Hiragino Sans","Yu Gothic UI",system-ui,sans-serif;

  /* === Radii / shadows === */
  --r-sm:6px;
  --r:10px;
  --r-lg:14px;
  --shadow-1:0 1px 2px rgba(15,18,22,.04), 0 1px 1px rgba(15,18,22,.03);
  --shadow-2:0 6px 24px -8px rgba(15,18,22,.12), 0 2px 6px rgba(15,18,22,.05);

  /* === Score viz mode === */
  --score-mode: dot;
}

/* === Dark theme === */
html[data-theme="dark"]{
  --bg:#0d1014;
  --surface:#161a20;
  --surface-2:#11151b;
  --ink:#f1f3f5;
  --ink-2:#c4ccd6;
  --muted:#8a93a0;
  --muted-2:#5d6671;
  --border:#262c34;
  --border-2:#323942;
  --soft:#1e2329;
  --hover:#1c2127;
  --accent-soft:#0d2a27;
  --keio-soft:#27182f;
  --odakyu-soft:#152238;
  --tokyu-soft:#2c1a10;
  --shadow-1:0 1px 0 rgba(0,0,0,.35);
  --shadow-2:0 8px 28px -8px rgba(0,0,0,.55);
}

/* === Editorial theme (paper-like, serif headings) === */
html[data-theme="editorial"]{
  --bg:#f3ede2;
  --surface:#fbf7ee;
  --surface-2:#ede5d4;
  --ink:#1a1611;
  --ink-2:#3e372d;
  --muted:#7c7464;
  --muted-2:#a89e88;
  --border:#d9d0bb;
  --border-2:#c8bda3;
  --soft:#e7dfcd;
  --hover:#ece4d2;
  --accent-soft:#e7e0d1;
}
html[data-theme="editorial"] h1,
html[data-theme="editorial"] .pricecell-big,
html[data-theme="editorial"] .card-price,
html[data-theme="editorial"] .cmp-head .price,
html[data-theme="editorial"] .modal h2{
  font-family: "Noto Serif JP","Times New Roman",serif;
  letter-spacing:0;
}
html[data-theme="editorial"] .brand-mark{
  font-family:"Noto Serif JP",serif;
  font-style:italic;
}

/* === Reset === */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);
  font-family:var(--font-sans);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"palt","cv11";
}
body{min-height:100vh}
a{color:inherit}
button{font-family:inherit}
::selection{background:var(--accent);color:var(--accent-ink)}

/* === Header === */
.site-head{
  padding:28px 32px 22px;
  border-bottom:1px solid var(--border);
  background:var(--surface);
  display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.site-head .brand{display:flex;flex-direction:column;gap:4px;min-width:0}
.brand-mark{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;display:flex;align-items:center;gap:8px;
}
.brand-mark::before{content:"";width:18px;height:1px;background:var(--ink-2);display:inline-block}
.site-head h1{
  margin:0;font-size:30px;font-weight:700;letter-spacing:-.018em;line-height:1.15;
  font-family:var(--font-jp);
}
.site-head .sub{color:var(--muted);font-size:13px;margin-top:2px;letter-spacing:.01em}
.site-head .quick-stats{
  display:flex;gap:0;align-items:stretch;
  border:1px solid var(--border);border-radius:var(--r);background:var(--surface);
  overflow:hidden;font-variant-numeric:tabular-nums;
}
.site-head .quick-stats .qs{
  padding:10px 18px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border);
  min-width:96px;
}
.site-head .quick-stats .qs:last-child{border-right:0}
.site-head .quick-stats .qs .l{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600}
.site-head .quick-stats .qs .v{font-size:18px;font-weight:700;color:var(--ink);font-family:var(--font-num);letter-spacing:-.01em}
.site-head .quick-stats .qs .v small{font-size:11px;color:var(--muted);font-weight:500;margin-left:2px}

/* === Toolbar === */
.toolbar{
  display:flex;flex-wrap:wrap;gap:10px 12px;align-items:end;
  padding:14px 32px;background:var(--surface-2);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:30;
  backdrop-filter:saturate(140%) blur(6px);
  -webkit-backdrop-filter:saturate(140%) blur(6px);
}
.toolbar.scrolled{box-shadow:var(--shadow-1)}
.field{display:flex;flex-direction:column;gap:5px;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.field label{padding-left:2px}
select,input[type=text]{
  appearance:none;border:1px solid var(--border);background:var(--surface);
  padding:8px 30px 8px 12px;border-radius:8px;
  font-size:13px;color:var(--ink);font-family:inherit;font-weight:500;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%237a818d' fill='none' stroke-width='1.5' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 11px center;min-width:140px;
  transition:.15s border-color, .15s box-shadow;
}
select:hover,input[type=text]:hover{border-color:var(--border-2)}
select:focus,input[type=text]:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 16%, transparent)}
input[type=text]{background-image:none;padding-right:12px;min-width:200px}
input[type=text]::placeholder{color:var(--muted-2)}

/* View switch — segmented */
.view-switch{
  display:inline-flex;background:var(--surface);
  border:1px solid var(--border);border-radius:9px;
  padding:3px;gap:2px;margin-left:auto;
}
.view-switch button{
  appearance:none;border:0;background:transparent;
  color:var(--muted);font-size:12px;font-weight:600;
  padding:7px 14px;border-radius:6px;cursor:pointer;letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:6px;
  transition:.12s background, .12s color;
  font-family:inherit;
}
.view-switch button:hover{color:var(--ink)}
.view-switch button.active{background:var(--ink);color:var(--surface)}
html[data-theme="dark"] .view-switch button.active{background:var(--accent);color:var(--accent-ink)}
.view-switch button .vbadge{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--accent);color:var(--accent-ink);
  border-radius:99px;padding:0 6px;font-size:10px;font-weight:700;
  min-width:16px;height:16px;line-height:1;
}
.view-switch button.active .vbadge{background:var(--surface);color:var(--ink)}

/* Tweaks float button */
.tw-fab{
  appearance:none;border:1px solid var(--border);background:var(--surface);
  color:var(--ink-2);font-size:12px;font-weight:600;
  padding:8px 12px;border-radius:8px;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  font-family:inherit;
}
.tw-fab:hover{border-color:var(--ink);color:var(--ink)}
.tw-fab .gear{width:14px;height:14px;display:inline-block;background:currentColor;
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><circle cx='12' cy='12' r='3'/><path d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 1 1-2.83 2.83l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 1 1-4 0v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 1 1-2.83-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 1 1 0-4h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 1 1 2.83-2.83l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 1 1 4 0v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 1 1 2.83 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 1 1 0 4h-.09a1.65 1.65 0 0 0-1.51 1z'/></svg>") center/contain no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2'><circle cx='12' cy='12' r='3'/><path d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 1 1-2.83 2.83l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 1 1-4 0v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 1 1-2.83-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 1 1 0-4h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 1 1 2.83-2.83l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 1 1 4 0v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 1 1 2.83 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 1 1 0 4h-.09a1.65 1.65 0 0 0-1.51 1z'/></svg>") center/contain no-repeat;
}

/* === Meta bar === */
.meta{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:14px 22px;flex-wrap:wrap}
.meta strong{color:var(--ink);font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}
.legend{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.legend .ldot{width:8px;height:8px;border-radius:50%;background:var(--muted);border:1.5px solid var(--surface);box-shadow:0 0 0 1px var(--muted);display:inline-block}
.legend .ldot.acc{background:var(--accent);box-shadow:0 0 0 1px var(--accent)}
.legend .lscale{display:inline-block;width:60px;height:4px;background:var(--soft);border-radius:2px;position:relative;vertical-align:middle;margin:0 2px}
.legend .lscale .ldot{position:absolute;top:50%;right:0;transform:translate(50%,-50%)}

/* === Layout === */
main{padding:22px 32px 64px}
.section-eyebrow{
  display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:14px;
  font-size:11px;text-transform:uppercase;letter-spacing:.18em;
  color:var(--muted);font-weight:600;
}
.section-eyebrow .l{display:flex;align-items:center;gap:10px}
.section-eyebrow .l::before{content:"";width:18px;height:1px;background:var(--ink-2)}

/* === BADGES (line colors front and center) === */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 8px;border-radius:99px;
  font-size:10.5px;font-weight:600;letter-spacing:.04em;
  background:var(--soft);color:var(--ink-2);
  white-space:nowrap;line-height:1.4;
  border:1px solid transparent;
}
.badge.line{
  background:var(--surface);
  color:var(--ink-2);
  border:1px solid var(--border);
  padding-left:8px;
  font-weight:700;
}
.badge.line::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--muted);margin-right:6px;
}
.badge.line[data-line="京王線"]{color:var(--keio);background:var(--keio-soft);border-color:color-mix(in srgb, var(--keio) 25%, transparent)}
.badge.line[data-line="京王線"]::before{background:var(--keio)}
.badge.line[data-line="小田急線"]{color:var(--odakyu);background:var(--odakyu-soft);border-color:color-mix(in srgb, var(--odakyu) 25%, transparent)}
.badge.line[data-line="小田急線"]::before{background:var(--odakyu)}
.badge.line[data-line="東急大井町線"]{color:var(--tokyu);background:var(--tokyu-soft);border-color:color-mix(in srgb, var(--tokyu) 25%, transparent)}
.badge.line[data-line="東急大井町線"]::before{background:var(--tokyu)}

.badge.best{
  background:var(--accent-soft);color:var(--accent);
  font-weight:700;
  border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);
}
.badge.best::before{content:"★";margin-right:3px;font-size:9px}

/* === Compare add button === */
.cmp-toggle{
  appearance:none;border:1px solid var(--border);background:var(--surface);
  width:28px;height:28px;border-radius:8px;cursor:pointer;
  color:var(--muted);font-size:14px;font-weight:700;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  transition:.12s; padding:0; flex-shrink:0; font-family:inherit;
}
.cmp-toggle:hover{border-color:var(--ink);color:var(--ink)}
.cmp-toggle.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.cmp-toggle.on:hover{background:var(--accent-2);border-color:var(--accent-2)}

/* ============================================================
   TABLE VIEW
   ============================================================ */
.tablewrap{
  overflow:auto;border:1px solid var(--border);border-radius:var(--r-lg);
  background:var(--surface);box-shadow:var(--shadow-1);
}
table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px;min-width:1100px}
thead th{
  position:sticky;top:0;background:var(--surface);z-index:5;text-align:left;
  padding:14px 14px;border-bottom:1px solid var(--border);
  color:var(--muted);font-weight:600;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;
}
thead th.sortable{cursor:pointer;user-select:none}
thead th.sortable:hover{color:var(--ink)}
thead th .arrow{display:inline-block;width:8px;color:var(--accent);margin-left:4px}
tbody td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:last-child td{border-bottom:0}
tbody tr{transition:background .1s}
tbody tr:hover{background:var(--hover);cursor:pointer}
.name{
  font-weight:700;color:var(--ink);max-width:280px;line-height:1.35;
  font-family:var(--font-jp);font-size:13.5px;
}
.name small{display:block;color:var(--muted);font-weight:400;font-size:11px;margin-top:3px;letter-spacing:0}

/* === Metric cell — score viz modes === */
.metric{display:flex;flex-direction:column;gap:6px;min-width:118px}
.metric .val{
  font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink);
  font-size:14px;display:flex;align-items:baseline;justify-content:flex-end;gap:1px;
  white-space:nowrap;line-height:1.2;font-family:var(--font-num);
  letter-spacing:-.005em;
}
.metric .val .u{font-size:10px;color:var(--muted);font-weight:500;margin-left:3px;letter-spacing:0}
.metric .val .star{
  color:var(--accent);font-size:11px;margin-left:6px;font-weight:700;
}
.metric.price .val{font-size:16px;font-weight:700}
.metric.best .val{color:var(--accent)}
.metric.worst .val{color:var(--muted-2);font-weight:500}

/* Mode: dot (default) */
.metric .scale{position:relative;height:4px;background:var(--soft);border-radius:2px;margin:0 4px}
.metric .scale::before,.metric .scale::after{content:"";position:absolute;top:50%;width:1px;height:8px;background:var(--border-2);transform:translateY(-50%)}
.metric .scale::before{left:0}.metric .scale::after{right:0}
.metric .scale .dot{
  position:absolute;top:50%;width:10px;height:10px;border-radius:50%;
  background:var(--ink-2);transform:translate(-50%,-50%);border:2px solid var(--surface);
  box-shadow:0 0 0 1px var(--ink-2);transition:transform .15s;
}
.metric .scale .fill{display:none;position:absolute;top:0;left:0;height:100%;background:var(--ink-2);border-radius:2px}
.metric.best .scale .dot{background:var(--accent);box-shadow:0 0 0 1px var(--accent);width:11px;height:11px}
.metric.best .scale .fill{background:var(--accent)}
.metric.worst .scale .dot{background:var(--muted-2);box-shadow:0 0 0 1px var(--muted-2)}
tbody tr:hover .metric .scale .dot{transform:translate(-50%,-50%) scale(1.15)}

/* Mode: bar */
:root[data-score="bar"] .metric .scale .dot{display:none}
:root[data-score="bar"] .metric .scale{height:6px}
:root[data-score="bar"] .metric .scale .fill{display:block}

/* Mode: heatmap (cell bg coloring; rail hidden) */
:root[data-score="heatmap"] .metric .scale{display:none}
:root[data-score="heatmap"] .metric{
  background:linear-gradient(to right,
    color-mix(in srgb, var(--accent) calc(var(--good-pct,50%) * 0.18), transparent),
    color-mix(in srgb, var(--accent) calc(var(--good-pct,50%) * 0.18), transparent));
  padding:10px 12px;border-radius:8px;margin:-4px;
}
:root[data-score="heatmap"] tbody td{padding:10px}

/* Mode: none */
:root[data-score="none"] .metric .scale{display:none}
:root[data-score="none"] .metric{gap:0}

/* === Card view === */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:0;display:flex;flex-direction:column;
  cursor:pointer;transition:.15s ease;
  overflow:hidden;position:relative;box-shadow:var(--shadow-1);
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--muted-2);
}
.card[data-line="京王線"]::before{background:var(--keio)}
.card[data-line="小田急線"]::before{background:var(--odakyu)}
.card[data-line="東急大井町線"]::before{background:var(--tokyu)}
.card:hover{border-color:var(--ink-2);transform:translateY(-2px);box-shadow:var(--shadow-2)}
.card .top{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;
  padding:18px 20px 14px;
}
.card .top-left{min-width:0;display:flex;flex-direction:column;gap:8px}
.card h3{
  margin:0;font-size:16px;font-weight:700;line-height:1.32;
  color:var(--ink);font-family:var(--font-jp);letter-spacing:.005em;
}
.card .station{font-size:11.5px;color:var(--muted);line-height:1.45}
.card .top-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0}
.card .price{
  font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--ink);
  font-variant-numeric:tabular-nums;white-space:nowrap;font-family:var(--font-num);
  line-height:1;
}
.card .price small{
  display:inline-block;color:var(--muted);font-weight:500;font-size:11px;
  margin-left:3px;letter-spacing:0;
}
.card .specs{
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px 18px;
  font-size:12px;color:var(--muted);
  padding:14px 20px 14px;
  border-top:1px solid var(--border);
  background:linear-gradient(to bottom, var(--surface) 0%, var(--surface-2) 100%);
}
.card .specs strong{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.card .tags{
  display:flex;flex-wrap:wrap;gap:5px;
  padding:0 20px 16px;
  margin-top:auto;
}
.card .tags:empty{padding:0}

/* === Charts === */
.charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:900px){.charts{grid-template-columns:1fr}}
.chartbox{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:22px;box-shadow:var(--shadow-1);
}
.chartbox h3{
  margin:0 0 4px;font-size:14px;font-weight:700;
  font-family:var(--font-jp);letter-spacing:.005em;color:var(--ink);
  display:flex;align-items:center;gap:8px;
}
.chartbox h3::before{
  content:"";width:3px;height:14px;background:var(--accent);border-radius:2px;
}
.chartbox p{margin:0 0 16px;font-size:12px;color:var(--muted);line-height:1.5}

/* === Detail Modal === */
.overlay{
  position:fixed;inset:0;background:rgba(15,18,22,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;z-index:60;padding:24px;
}
.overlay.show{display:flex}
.modal{
  background:var(--surface);border-radius:var(--r-lg);
  max-width:820px;width:100%;max-height:88vh;max-height:88dvh;
  overflow:auto;padding:32px;border:1px solid var(--border);
  position:relative;box-shadow:var(--shadow-2);
}
.modal h2{margin:0 0 4px;font-size:22px;font-family:var(--font-jp);letter-spacing:-.005em;font-weight:700}
.modal .sub{font-size:12px;color:var(--muted);margin-top:2px}
.modal .closebtn{
  position:absolute;top:18px;right:18px;border:1px solid var(--border);
  background:var(--surface);font-size:18px;color:var(--muted);cursor:pointer;
  width:32px;height:32px;border-radius:8px;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
}
.modal .closebtn:hover{border-color:var(--ink);color:var(--ink)}
.modal .grid2{
  display:grid;grid-template-columns:1fr 1fr;gap:0 28px;font-size:13px;margin-top:20px;
}
.modal .grid2 .row{
  display:flex;justify-content:space-between;border-bottom:1px solid var(--border);
  padding:9px 0;gap:10px;
}
.modal .grid2 .row span:first-child{color:var(--muted);font-size:11.5px}
.modal .grid2 .row span:last-child{color:var(--ink);font-weight:600;text-align:right;font-variant-numeric:tabular-nums}
.modal .features{
  margin-top:18px;font-size:13px;color:var(--ink);line-height:1.7;
  background:var(--surface-2);padding:14px 16px;border-radius:8px;border:1px solid var(--border);
}
.modal .features strong{display:block;margin-bottom:6px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-weight:600}
.modal .reviews{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}
@media (max-width:640px){.modal .reviews{grid-template-columns:1fr}}
.reviewbox{padding:14px 16px;border-radius:8px;border:1px solid var(--border);font-size:12.5px;line-height:1.7}
.reviewbox h4{margin:0 0 8px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:6px;font-weight:700}
.reviewbox h4 .dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.reviewbox.pros{background:color-mix(in srgb, var(--good) 7%, var(--surface));border-color:color-mix(in srgb, var(--good) 25%, var(--border))}
.reviewbox.pros h4{color:var(--good)}
.reviewbox.pros h4 .dot{background:var(--good)}
.reviewbox.cons{background:color-mix(in srgb, var(--bad) 6%, var(--surface));border-color:color-mix(in srgb, var(--bad) 22%, var(--border))}
.reviewbox.cons h4{color:var(--bad)}
.reviewbox.cons h4 .dot{background:var(--bad)}
.reviewbox ul{margin:0;padding-left:18px;color:var(--ink)}
.reviewbox ul li{margin:3px 0}
.reviewbox .empty-r{color:var(--muted);font-style:italic;font-size:12px}

/* === Compare === */
.cmp-cols{display:grid;gap:8px;align-items:stretch}
.cmp-cols.n2{grid-template-columns:160px 1fr 1fr}
.cmp-cols.n3{grid-template-columns:160px 1fr 1fr 1fr}
@media (max-width:760px){.cmp-cols.n2,.cmp-cols.n3{grid-template-columns:96px repeat(auto-fit,minmax(120px,1fr));font-size:12px}}
.cmp-cols .label{
  padding:12px 14px;font-size:11px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;font-weight:600;
  display:flex;align-items:center;
}
.cmp-cols .cell{
  padding:12px 16px;background:var(--surface);
  border:1px solid var(--border);border-radius:8px;font-size:13px;
  display:flex;align-items:center;gap:6px;color:var(--ink);
  min-height:44px;line-height:1.45;font-variant-numeric:tabular-nums;
}
.cmp-cols .cell.best{
  background:var(--accent-soft);border-color:color-mix(in srgb, var(--accent) 35%, transparent);
  color:var(--accent);font-weight:700;
}
.cmp-cols .cell.best::after{content:"★";margin-left:auto;font-size:11px}
.cmp-cols .cmp-features{
  padding:14px 16px;background:var(--surface-2);
  border:1px solid var(--border);border-radius:8px;
  font-size:12.5px;line-height:1.75;color:var(--ink);
}
.cmp-cols .cmp-features.pros{background:color-mix(in srgb, var(--good) 7%, var(--surface));border-color:color-mix(in srgb, var(--good) 22%, var(--border))}
.cmp-cols .cmp-features.cons{background:color-mix(in srgb, var(--bad) 6%, var(--surface));border-color:color-mix(in srgb, var(--bad) 18%, var(--border))}
.cmp-cols .cmp-features ul{margin:0;padding-left:16px}
.cmp-cols .cmp-features ul li{margin:3px 0}
.cmp-cols.cmp-headrow{margin-bottom:18px}
.cmp-head{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:16px;display:flex;flex-direction:column;gap:6px;position:relative;
  box-shadow:var(--shadow-1);overflow:hidden;
}
.cmp-head::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--muted-2);
}
.cmp-head:has(.badge.line[data-line="京王線"])::before{background:var(--keio)}
.cmp-head:has(.badge.line[data-line="小田急線"])::before{background:var(--odakyu)}
.cmp-head:has(.badge.line[data-line="東急大井町線"])::before{background:var(--tokyu)}
.cmp-head .badge.line{align-self:flex-start;margin-top:4px}
.cmp-head .name{font-weight:700;font-size:14px;line-height:1.35;margin-top:6px;font-family:var(--font-jp)}
.cmp-head .station{font-size:11px;color:var(--muted);line-height:1.45}
.cmp-head .price{
  font-size:24px;font-weight:700;font-variant-numeric:tabular-nums;
  margin-top:10px;color:var(--ink);white-space:nowrap;letter-spacing:-.018em;
  font-family:var(--font-num);line-height:1;
}
.cmp-head .price small{font-size:11px;color:var(--muted);font-weight:500;margin-left:3px}
.cmp-head .price .star{font-size:14px;margin-left:6px;color:var(--accent)}
.cmp-head .remove{
  position:absolute;top:8px;right:8px;background:transparent;border:0;
  color:var(--muted);cursor:pointer;font-size:16px;
  width:28px;height:28px;border-radius:6px;line-height:1;
  display:flex;align-items:center;justify-content:center;
}
.cmp-head .remove:hover{background:var(--soft);color:var(--ink)}
.cmp-section-title{
  padding:24px 0 12px;font-size:11px;color:var(--ink);
  text-transform:uppercase;letter-spacing:.16em;font-weight:700;
  border-bottom:1px solid var(--border);margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.cmp-section-title::before{content:"";width:3px;height:11px;background:var(--accent);border-radius:2px}
.cmp-empty{
  padding:64px 24px;text-align:center;color:var(--muted);font-size:13px;
  background:var(--surface);border:1px dashed var(--border-2);border-radius:var(--r-lg);
  line-height:1.9;
}
.cmp-empty strong{color:var(--ink);font-weight:700;font-size:14px;display:block;margin-bottom:4px}

/* === Map === */
.map-layout{display:grid;grid-template-columns:1fr 360px;gap:14px;height:calc(100vh - 250px);min-height:540px}
@media (max-width:900px){.map-layout{grid-template-columns:1fr;height:auto}.map-canvas{height:440px}.map-list{max-height:360px}}
.map-canvas{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--soft);z-index:1;box-shadow:var(--shadow-1)}
.map-list{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--surface);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-1)}
.map-list-header{
  padding:14px 16px;font-size:11px;color:var(--muted);
  border-bottom:1px solid var(--border);background:var(--surface-2);
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  display:flex;justify-content:space-between;align-items:center;
}
.map-list-items{overflow-y:auto;flex:1}
.map-item{padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:.12s;display:flex;flex-direction:column;gap:5px;position:relative}
.map-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent}
.map-item:hover{background:var(--hover)}
.map-item.active{background:var(--accent-soft)}
.map-item.active::before{background:var(--accent)}
.map-item .l1{
  font-weight:700;font-size:13px;line-height:1.35;
  display:flex;justify-content:space-between;gap:8px;align-items:flex-start;color:var(--ink);
  font-family:var(--font-jp);
}
.map-item .l1 .p{
  font-variant-numeric:tabular-nums;color:var(--ink);
  white-space:nowrap;font-size:14px;font-weight:700;font-family:var(--font-num);
}
.map-item .l1 .p.cmp::before{content:"★ ";color:var(--accent);font-size:11px}
.map-item .l2{font-size:11px;color:var(--muted);line-height:1.5;display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.map-item .l2 .badge{font-size:9.5px;padding:1px 6px;margin:0}

.map-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--muted);padding:0 4px 10px}
.map-legend .lg{display:inline-flex;align-items:center;gap:6px;color:var(--ink-2);font-weight:500}
.map-legend .pin-mini{display:inline-block;width:14px;height:8px;border:1.5px solid var(--ink-2);border-radius:2px;background:var(--surface)}
.map-legend .pin-mini.k{border-color:var(--keio)}
.map-legend .pin-mini.o{border-color:var(--odakyu)}
.map-legend .pin-mini.t{border-color:var(--tokyu)}
.map-legend .pin-mini.c{background:var(--accent);border-color:var(--accent)}

.leaflet-div-icon, .marker-wrapper{background:transparent!important;border:0!important}
.marker-pin{
  position:relative;background:var(--surface);
  border:2px solid var(--ink);padding:4px 9px;border-radius:7px;
  font-size:11.5px;font-weight:700;font-variant-numeric:tabular-nums;
  box-shadow:0 2px 8px rgba(15,18,22,.20);white-space:nowrap;cursor:pointer;
  color:var(--ink);font-family:var(--font-num);text-align:center;
}
.marker-pin::after{
  content:"";position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);
  width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;
  border-top:7px solid var(--ink);
}
.marker-pin.line-keio{border-color:var(--keio);color:var(--keio);background:var(--surface)}
.marker-pin.line-keio::after{border-top-color:var(--keio)}
.marker-pin.line-odakyu{border-color:var(--odakyu);color:var(--odakyu);background:var(--surface)}
.marker-pin.line-odakyu::after{border-top-color:var(--odakyu)}
.marker-pin.line-tokyu{border-color:var(--tokyu);color:var(--tokyu);background:var(--surface)}
.marker-pin.line-tokyu::after{border-top-color:var(--tokyu)}
.marker-pin.cmp{background:var(--accent)!important;color:var(--accent-ink)!important;border-color:var(--accent)!important}
.marker-pin.cmp::after{border-top-color:var(--accent)!important}
.marker-pin .star{display:none;margin-right:2px}
.marker-pin.cmp .star{display:inline}
.marker-pin:hover{transform:scale(1.07);z-index:1000}

.leaflet-popup-content-wrapper{
  border-radius:var(--r)!important;padding:8px!important;
  box-shadow:var(--shadow-2)!important;border:1px solid var(--border);
  background:var(--surface)!important;color:var(--ink)!important;
}
.leaflet-popup-content{margin:8px 12px!important;font-family:var(--font-sans)!important}
.leaflet-popup-tip{background:var(--surface)!important;box-shadow:none!important}
.map-popup{font-size:12px;color:var(--ink);min-width:220px}
.map-popup .badge.line{margin-bottom:4px;display:inline-block}
.map-popup .popup-name{font-weight:700;font-size:13.5px;line-height:1.35;margin:6px 0 2px;font-family:var(--font-jp)}
.map-popup .popup-station{font-size:11px;color:var(--muted);margin-bottom:10px;line-height:1.45}
.map-popup .popup-price{font-size:20px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums;margin-bottom:4px;letter-spacing:-.018em;font-family:var(--font-num)}
.map-popup .popup-price small{font-size:10px;color:var(--muted);font-weight:500;margin-left:2px}
.map-popup .popup-specs{font-size:11px;color:var(--muted);margin-bottom:12px}
.map-popup .popup-actions{display:flex;gap:6px;flex-wrap:wrap}
.popup-btn{
  appearance:none;border:1px solid var(--border);background:var(--surface);
  color:var(--ink);padding:7px 12px;border-radius:6px;font-size:11.5px;cursor:pointer;
  font-family:inherit;font-weight:600;
}
.popup-btn:hover{background:var(--hover)}
.popup-btn.primary{background:var(--ink);color:var(--surface);border-color:var(--ink)}
.popup-btn.primary:hover{opacity:.9}
.popup-btn.cmp-on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

.marker-cluster{background:rgba(15,18,22,.15)!important}
.marker-cluster div{background:var(--ink)!important;color:var(--surface)!important;font-weight:700!important;font-family:var(--font-num)!important}

/* === Tweaks panel === */
.tw-panel{
  position:fixed;top:78px;right:18px;width:280px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-2);
  z-index:80;padding:0;font-size:13px;
  display:none;flex-direction:column;max-height:calc(100vh - 100px);overflow:auto;
}
.tw-panel.show{display:flex}
.tw-panel header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid var(--border);background:var(--surface);
  position:sticky;top:0;z-index:1;
}
.tw-panel header h4{margin:0;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:700}
.tw-panel header button{
  appearance:none;border:0;background:transparent;color:var(--muted);
  font-size:18px;cursor:pointer;width:24px;height:24px;border-radius:5px;
}
.tw-panel header button:hover{background:var(--soft);color:var(--ink)}
.tw-section{padding:14px 16px;border-bottom:1px solid var(--border)}
.tw-section:last-child{border-bottom:0}
.tw-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700;margin-bottom:10px}
.tw-radio{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.tw-radio button{
  appearance:none;border:1px solid var(--border);background:var(--surface);
  color:var(--ink-2);font-size:11.5px;font-weight:600;
  padding:9px 4px;border-radius:7px;cursor:pointer;
  font-family:inherit;text-align:center;
  transition:.12s;
}
.tw-radio button:hover{border-color:var(--ink-2)}
.tw-radio button.on{background:var(--ink);color:var(--surface);border-color:var(--ink)}
html[data-theme="dark"] .tw-radio button.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.tw-radio.cols-2{grid-template-columns:repeat(2,1fr)}
.tw-radio.cols-4{grid-template-columns:repeat(4,1fr)}
.tw-swatches{display:flex;gap:8px}
.tw-sw{
  width:30px;height:30px;border-radius:50%;cursor:pointer;
  border:2px solid var(--surface);box-shadow:0 0 0 1px var(--border);
  transition:.12s;
}
.tw-sw:hover{transform:scale(1.08)}
.tw-sw.on{box-shadow:0 0 0 2px var(--ink)}

/* === Footer === */
footer{
  padding:22px 32px;font-size:11px;color:var(--muted);
  border-top:1px solid var(--border);background:var(--surface-2);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  font-weight:500;
}
footer .accent-info{color:var(--ink-2)}

.hidden{display:none!important}
.empty{padding:48px;text-align:center;color:var(--muted);font-size:13px}

/* === Mobile === */
@media (max-width:768px){.toolbar{position:static}}
@media (max-width:640px){
  .site-head{padding:18px 16px 14px;flex-direction:column;align-items:flex-start}
  .site-head h1{font-size:22px}
  .site-head .quick-stats{width:100%;overflow-x:auto}
  .site-head .quick-stats .qs{min-width:88px}
  main{padding:16px 14px 48px}
  .toolbar{padding:12px 14px;gap:10px}
  select,input[type=text]{min-width:0;width:100%;font-size:12px}
  .field{flex:1 1 calc(50% - 4px);min-width:0}
  .search-field{flex:1 1 100%}
  .view-switch{margin-left:0;width:100%}
  .view-switch button{flex:1;padding:7px 4px;font-size:11px;letter-spacing:.02em}
  .meta{font-size:10px;line-height:1.5;display:flex;flex-wrap:wrap;align-items:center;gap:4px 10px}
  .meta strong{font-size:11px}
  .grid{grid-template-columns:1fr;gap:12px}
  .card .top{padding:14px 16px 12px}
  .card .specs{padding:12px 16px;font-size:11px;gap:6px 12px}
  .card .tags{padding:0 16px 14px}
  .card h3{font-size:14px}
  .card .price{font-size:20px}
  .overlay{padding:8px;align-items:flex-end}
  .modal{border-radius:14px 14px 0 0;max-height:92vh;max-height:92dvh;padding:20px 16px}
  .modal h2{font-size:18px;padding-right:36px}
  .modal .grid2{grid-template-columns:1fr;gap:0}
  .cmp-cols.n2,.cmp-cols.n3{grid-template-columns:80px repeat(auto-fit,minmax(100px,1fr));font-size:11px}
  .map-layout{height:auto}
  .map-canvas{height:340px}
  .map-list{max-height:280px}
  footer{padding:14px;flex-direction:column;gap:4px}
  .tw-panel{top:auto;bottom:0;right:0;left:0;width:auto;border-radius:14px 14px 0 0}
}


/* ============================================================
   EXPRESSIVE TWEAKS — reshape the feel
   ============================================================ */

/* === VIBE: Brutalist === */
html[data-vibe="brutal"]{
  --r-sm:0; --r:0; --r-lg:0;
  --border:#0e1116;
  --border-2:#0e1116;
  --shadow-1:none;
  --shadow-2:4px 4px 0 #0e1116;
}
html[data-vibe="brutal"] body{font-family:"Inter","Noto Sans JP",monospace}
html[data-vibe="brutal"] .site-head{border-bottom-width:2px}
html[data-vibe="brutal"] .site-head h1{font-weight:800;letter-spacing:-.03em}
html[data-vibe="brutal"] .badge,
html[data-vibe="brutal"] .toolbar,
html[data-vibe="brutal"] .tablewrap,
html[data-vibe="brutal"] .card,
html[data-vibe="brutal"] .chartbox,
html[data-vibe="brutal"] .map-canvas,
html[data-vibe="brutal"] .map-list,
html[data-vibe="brutal"] .modal,
html[data-vibe="brutal"] .cmp-head,
html[data-vibe="brutal"] .tw-panel,
html[data-vibe="brutal"] select,
html[data-vibe="brutal"] input[type=text],
html[data-vibe="brutal"] .view-switch,
html[data-vibe="brutal"] .tw-fab{border-width:2px;border-color:#0e1116;box-shadow:none}
html[data-vibe="brutal"] .card{box-shadow:4px 4px 0 #0e1116}
html[data-vibe="brutal"] .card::before{height:6px}
html[data-vibe="brutal"] .view-switch button.active{background:#0e1116;color:#fff}
html[data-vibe="brutal"] .pricecell, html[data-vibe="brutal"] .card .price,
html[data-vibe="brutal"] .cmp-head .price{font-weight:800;letter-spacing:-.03em}
html[data-vibe="brutal"] .badge.line{border-width:2px;border-radius:0;font-weight:800}
html[data-vibe="brutal"][data-theme="dark"] .card,
html[data-vibe="brutal"][data-theme="dark"] .modal{box-shadow:4px 4px 0 #f1f3f5}

/* === VIBE: Soft === */
html[data-vibe="soft"]{
  --r-sm:14px; --r:18px; --r-lg:24px;
  --shadow-1:0 2px 6px rgba(15,18,22,.05), 0 1px 2px rgba(15,18,22,.04);
  --shadow-2:0 16px 40px -12px rgba(15,18,22,.18), 0 4px 10px rgba(15,18,22,.06);
}
html[data-vibe="soft"] .card{padding:0;border-width:0;background:var(--surface);box-shadow:var(--shadow-2)}
html[data-vibe="soft"] .card::before{height:0}
html[data-vibe="soft"] .card .top{padding:22px 24px 16px}
html[data-vibe="soft"] .card .specs{padding:18px 24px;background:transparent;border-top:1px dashed var(--border)}
html[data-vibe="soft"] .card .tags{padding:0 24px 20px}
html[data-vibe="soft"] .badge{padding:5px 11px;font-weight:500}
html[data-vibe="soft"] .badge.line{font-weight:600}
html[data-vibe="soft"] .toolbar{border-bottom:0;background:transparent;backdrop-filter:none}
html[data-vibe="soft"] select,
html[data-vibe="soft"] input[type=text],
html[data-vibe="soft"] .tw-fab{background:var(--surface);border-color:transparent;box-shadow:var(--shadow-1)}
html[data-vibe="soft"] .view-switch{background:var(--surface);border-color:transparent;box-shadow:var(--shadow-1)}
html[data-vibe="soft"] .site-head{border-bottom:0}

/* === EMPHASIS: name-led (物件名を主役に) === */
html[data-emphasis="name"] .card .top{flex-direction:column;align-items:stretch;gap:14px}
html[data-emphasis="name"] .card h3{font-size:22px;line-height:1.25;font-weight:800;letter-spacing:-.01em;order:2}
html[data-emphasis="name"] .card .top-left{gap:10px}
html[data-emphasis="name"] .card .top-right{flex-direction:row;align-items:center;justify-content:space-between;width:100%;order:3}
html[data-emphasis="name"] .card .price{font-size:18px;font-weight:600;color:var(--ink-2);letter-spacing:0}
html[data-emphasis="name"] .card .station{font-size:12px}
html[data-emphasis="name"] .map-item .l1{font-size:15px}
html[data-emphasis="name"] .map-item .l1 .p{font-size:12px;color:var(--muted);font-weight:500}

/* === EMPHASIS: line-led (沿線を主役に) === */
html[data-emphasis="line"] .card{border-left:4px solid var(--muted-2)}
html[data-emphasis="line"] .card[data-line="京王線"]{border-left-color:var(--keio)}
html[data-emphasis="line"] .card[data-line="小田急線"]{border-left-color:var(--odakyu)}
html[data-emphasis="line"] .card[data-line="東急大井町線"]{border-left-color:var(--tokyu)}
html[data-emphasis="line"] .card::before{height:0}
html[data-emphasis="line"] .card[data-line="京王線"]{background:linear-gradient(to right, var(--keio-soft) 0%, var(--surface) 35%)}
html[data-emphasis="line"] .card[data-line="小田急線"]{background:linear-gradient(to right, var(--odakyu-soft) 0%, var(--surface) 35%)}
html[data-emphasis="line"] .card[data-line="東急大井町線"]{background:linear-gradient(to right, var(--tokyu-soft) 0%, var(--surface) 35%)}
html[data-emphasis="line"] .badge.line{font-size:12px;padding:5px 12px}
html[data-emphasis="line"] .card .specs{background:transparent}
html[data-emphasis="line"] .marker-pin{font-size:13px;padding:5px 11px;border-width:3px}

/* === EMPHASIS: price-led is the default; explicit rule for clarity === */
html[data-emphasis="price"] .card .price{font-size:30px;letter-spacing:-.025em;font-weight:800}
html[data-emphasis="price"] .card h3{font-size:14px;color:var(--ink-2);font-weight:600}
html[data-emphasis="price"] .pricecell-big{font-size:20px}

/* === DENSITY: compact === */
html[data-density="compact"] .card .top{padding:12px 14px 10px}
html[data-density="compact"] .card .specs{padding:10px 14px;font-size:11px;gap:5px 12px}
html[data-density="compact"] .card .tags{padding:0 14px 12px;gap:4px}
html[data-density="compact"] .card h3{font-size:14px}
html[data-density="compact"] .card .price{font-size:20px}
html[data-density="compact"] tbody td{padding:8px 12px}
html[data-density="compact"] thead th{padding:9px 12px}
html[data-density="compact"] main{padding:14px 24px 48px}
html[data-density="compact"] .grid{gap:10px}
