/* styles.css — シンプルで洗練された見た目（据え置き） */ 
:root{
  --bg: hsl(0 0% 100%);
  --fg: hsl(222 25% 12%);
  --muted: hsl(222 10% 45%);
  --accent: hsl(222 90% 56%);
  --card: hsl(0 0% 100%);
  --border: hsl(220 14% 90%);
  --radius: 14px;
  color-scheme: light dark;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg: hsl(230 20% 8%);
    --fg: hsl(0 0% 95%);
    --muted: hsl(220 10% 70%);
    --card: hsl(230 22% 12%);
    --border: hsl(230 12% 22%);
  }
}
*{ box-sizing: border-box; }
html,body{ margin:0; padding:0; background:var(--bg); color:var(--fg); font-family: Inter, "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif; }
h1,h2{ line-height:1.2; }
.container{ max-width: 1100px; padding: 20px; margin-inline:auto; }
.subtitle{ color:var(--muted); margin-top: .25rem; }

/* Header */
header{
  padding-block: 28px 12px;
}
.controls{
  display:flex; gap:.5rem; align-items:center; margin-top:14px;
  background:var(--card); border:1px solid var(--border); padding:.6rem .8rem; border-radius: var(--radius);
  width: fit-content;
}
label{ font-weight:600; }
select,button{
  appearance:none; border:1px solid var(--border); border-radius: 10px; padding:.45rem .7rem; background:var(--bg); color:var(--fg);
}

/* Table */
.table-wrap{
  overflow:auto;
  background:var(--card);
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 4px 24px rgba(0,0,0,.06);
}
table{
  width:100%;
  border-collapse: collapse;
  min-width: 760px;
}
thead th{
  position: sticky; top: 0; background: var(--card); z-index: 1;
}
th, td{
  text-align:center; padding: 12px 10px; border-bottom:1px solid var(--border);
}
tbody tr:hover{ background: color-mix(in oklab, var(--card), var(--accent) 4%); }
th.paper{ text-align:left; }
.paper-name{ font-weight:700; }
.paper-note{ font-size:.85rem; color:var(--muted); }

code{ background: color-mix(in oklab, var(--bg), var(--accent) 6%); padding:.15rem .35rem; border-radius: 8px; }

/* Notes */
.notes{ margin-top: 18px; }
.notes h2{ font-size: 1.1rem; margin: 10px 0; }
.notes ul{ margin:0; padding-left: 18px; line-height: 1.85; color: var(--muted); }
.notes li strong{ color: var(--fg); }

/* Footer */
.footer{ text-align:center; color: var(--muted); padding: 28px 0 40px; }

/* Small screens */
@media (max-width: 640px){
  .container{ padding: 14px; }
  .controls{ width: 100%; }
}
