/* KIRIKOM PLUS — minimal stylesheet */
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Hiragino Sans", "Yu Gothic UI", Meiryo, sans-serif;
  background: #f6f8fb;
  color: #222;
  line-height: 1.55;
}
a { color: #2a6df4; text-decoration: none; }
a:hover { text-decoration: underline; }

.kp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 24px; background: #1f2a44; color: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.15);
}
.kp-header a { color: #fff; }
.kp-brand a { font-weight: 700; font-size: 1.15rem; }
.kp-nav { display: flex; gap: 18px; align-items: center; }
.kp-user { font-size: .9rem; opacity: .85; }

.kp-main { max-width: 1200px; margin: 24px auto; padding: 0 24px 64px; }

.kp-card {
  background: #fff; border-radius: 8px; padding: 24px 28px; margin-bottom: 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.kp-card-narrow { max-width: 480px; margin: 60px auto; }
.kp-row-between { display:flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 12px; }
h1 { margin: 0 0 16px; font-size: 1.4rem; }
h2 { margin: 24px 0 8px; font-size: 1.1rem; border-bottom: 1px solid #e2e6ee; padding-bottom: 4px;}
h3 { margin: 20px 0 6px; font-size: 1rem; }

label { display: block; margin: 10px 0; font-size: .9rem; color: #555; }
input[type=text], input[type=email], input[type=password], input[type=datetime-local],
select, textarea {
  width: 100%; padding: 8px 10px; font-size: 1rem;
  border: 1px solid #c8cfdb; border-radius: 5px; background: #fff;
  margin-top: 4px;
}
textarea { resize: vertical; font-family: inherit; }
fieldset { border: 1px solid #e2e6ee; border-radius: 6px; padding: 12px 16px; margin: 16px 0; }
legend { padding: 0 6px; color: #444; font-weight: 600; }

.kp-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.kp-req { color: #d33; }
.kp-help { color: #666; font-size: .9rem; margin: 0 0 16px; }

.kp-btn {
  display: inline-block; padding: 8px 16px; border-radius: 5px;
  border: 1px solid #c8cfdb; background: #fff; color: #222; cursor: pointer; font-size: .95rem;
  text-decoration: none;
}
.kp-btn:hover { background: #f0f3f8; text-decoration: none; }
.kp-btn-primary { background: #2a6df4; color: #fff; border-color: #2a6df4; }
.kp-btn-primary:hover { background: #1a5cdc; }
.kp-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 18px; }

.kp-search { display:flex; gap:8px; margin: 10px 0 18px; }
.kp-search input[type=text] { flex: 1; }

.kp-table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.kp-table th, .kp-table td { border-bottom: 1px solid #eef1f6; padding: 8px 10px; text-align: left; }
.kp-table th { background: #fafbfd; color: #555; font-weight: 600; }
.kp-table .kp-num, .kp-num { text-align: right; font-variant-numeric: tabular-nums; }
.kp-empty { text-align: center; color: #888; padding: 24px; }

.kp-badge {
  display: inline-block; padding: 2px 8px; border-radius: 999px; font-size: .8rem;
  background: #e2e6ee; color: #333;
}
.kp-badge-new       { background: #e3f0ff; color: #14458d; }
.kp-badge-analyzing { background: #fff3d6; color: #7a5500; }
.kp-badge-analyzed  { background: #d6f5dc; color: #1e5e2c; }
.kp-badge-quoted    { background: #ddebff; color: #1a3b75; }
.kp-badge-accepted  { background: #c8e8d0; color: #135a23; }
.kp-badge-rejected  { background: #fadcdc; color: #8a1f1f; }
.kp-badge-done      { background: #d0d0d0; color: #333; }

.kp-thumb-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 16px; }
.kp-thumb-grid figure { margin: 0; background: #fafbfd; border: 1px solid #e8ecf3; border-radius: 6px; padding: 8px; }
.kp-thumb-grid img { width: 100%; height: 140px; object-fit: contain; background: #fff; }
.kp-thumb-grid figcaption { font-size: .8rem; color: #555; margin-top: 4px; }

.kp-result-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin: 12px 0; }
.kp-result-block { background: #f8fafd; border: 1px solid #e2e6ee; border-radius: 6px; padding: 12px 16px; text-align: center; }
.kp-result-label { font-size: .82rem; color: #666; }
.kp-result-value { font-size: 1.4rem; font-weight: 700; margin-top: 6px; }

.kp-flags { display: flex; flex-wrap: wrap; gap: 14px; padding: 0; list-style: none; font-size: .9rem; color: #555; }
.kp-flags li { background: #f2f5fa; padding: 4px 10px; border-radius: 4px; }

.kp-dl { display: grid; grid-template-columns: 120px 1fr; gap: 4px 12px; margin: 8px 0 16px; }
.kp-dl dt { color: #666; font-size: .85rem; }
.kp-dl dd { margin: 0; }

.kp-pre {
  white-space: pre-wrap; word-wrap: break-word;
  background: #f8fafd; border: 1px solid #e2e6ee; border-radius: 6px; padding: 10px 12px;
  font-family: inherit; font-size: .92rem;
}

.kp-flash { padding: 10px 14px; border-radius: 6px; margin: 8px 0 14px; font-size: .92rem; }
.kp-flash-success { background: #d6f5dc; color: #1e5e2c; }
.kp-flash-error   { background: #fadcdc; color: #8a1f1f; }
.kp-flash-warn    { background: #fff3d6; color: #7a5500; }
.kp-flash-info    { background: #e3f0ff; color: #14458d; }

.kp-footer { text-align: center; color: #888; font-size: .85rem; padding: 24px; }

.kp-check { display: flex; align-items: center; gap: 8px; }
.kp-check input { width: auto; }
