﻿:root {
  --bg: #eff4fb;
  --surface: #ffffff;
  --line: #d7deea;
  --text: #1b2840;
  --muted: #5f6f86;
  --danger: #a93030;
  --warning: #946219;
  --safe: #1f7f4f;
  --accent: #1e3f67;
}
* { box-sizing: border-box; }
body { margin: 0; font-family: "Segoe UI", "Yu Gothic", sans-serif; color: var(--text); background: radial-gradient(circle at 20% 0%, #f7faff 0%, #eff4fb 45%, #e9f0f8 100%); line-height: 1.65; }
a { color: #1d4d8f; text-decoration: none; }
a:hover { text-decoration: underline; }
.container { width: min(1120px, 92vw); margin: 0 auto; }
.site-header { background: rgba(255, 255, 255, 0.86); border-bottom: 1px solid #d9e4f4; position: sticky; top: 0; z-index: 9; backdrop-filter: blur(8px); }
.header-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px 0; }
.logo { font-weight: 800; color: #0f2440; letter-spacing: .02em; }
.nav { display: flex; gap: 14px; flex-wrap: wrap; }
.nav a { color: #395172; font-weight: 600; font-size: .95rem; }

.hero { padding: 28px 0 12px; }
.hero-split { display: grid; grid-template-columns: 1.05fr .95fr; gap: 16px; align-items: stretch; }
.hero h1 { font-size: clamp(1.7rem, 4vw, 2.3rem); margin: 0 0 10px; }
.hero p { margin: 0 0 14px; color: var(--muted); }
.hero-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.button { display: inline-block; border-radius: 12px; padding: 12px 16px; font-weight: 700; color: #fff; background: linear-gradient(135deg, #183252 0%, #28507d 100%); }
.button-sub { background: linear-gradient(135deg, #2b4a72 0%, #3f6a9d 100%); }
.text-link { font-weight: 700; }
.save-promo { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 14px; }
.save-promo h2 { margin: 0 0 8px; font-size: 1.1rem; }
.simple-hero { padding-top: 34px; }
.hero-subnote { font-size: .84rem; color: #6c7a8e; margin-bottom: 16px; }
.sample-judgement-card { padding: 18px; display: grid; gap: 10px; align-content: start; }
.sample-judgement-card h2 { margin: 0; font-size: 1.08rem; }
.sample-danger-title { margin: 0; font-size: .9rem; color: #516581; font-weight: 700; }
.sample-decision { margin: 0; color: #2a3f5f; }

.section { padding: 16px 0; }
.compact-section { padding-top: 8px; padding-bottom: 10px; }
.steps-grid { display: grid; gap: 12px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.step-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 14px; }
.step-no { display: inline-block; background: #e9f2ff; color: #15406b; border-radius: 999px; font-size: .78rem; font-weight: 700; padding: 2px 10px; }
.step-card h3 { margin: 8px 0 6px; font-size: 1rem; }
.guide-note { color: var(--muted); font-size: .92rem; margin-top: 10px; }
.demo-mini-card { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 14px; }
.demo-mini-label { margin: 0 0 8px; color: #4f627e; font-size: .9rem; }
.use-hint { margin: 0 0 8px; color: #5f6f86; font-size: .9rem; }
.use-tag-row .tag { padding: 6px 11px; }
.demo-flow-card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 14px; display: grid; gap: 10px; }
.mono-box { margin: 0; background: #f8fbff; border: 1px solid #dbe5f5; border-radius: 10px; padding: 10px; white-space: pre-line; font-size: .9rem; }
.use-grid { display: grid; gap: 10px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.use-card { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 12px; display: grid; gap: 4px; }
.use-card strong { color: #1c3658; }
.use-card span { color: var(--muted); font-size: .88rem; }

.grid { display: grid; gap: 12px; }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.card, .listing-demo { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 14px; }
.label { display: inline-block; border-radius: 999px; border: 1px solid var(--line); background: #f7f8fb; font-size: .78rem; padding: 2px 8px; }
.status-danger { color: var(--danger); }
.status-warning { color: var(--warning); }
.status-safe { color: var(--safe); }
.status-info { color: #18558c; }
.status-info-bg { background: #edf6ff; border-color: #cadef6; }

.check-hero { padding: 26px 0 8px; }
.check-hero h1 { margin: 0 0 8px; font-size: clamp(1.55rem, 4vw, 2.1rem); }
.check-hero p { margin: 0; color: var(--muted); }
.check-hero-actions { margin-top: 14px; }
.sample-jump-button { border: 0; cursor: pointer; }
.check-hero-note { margin-top: 10px !important; font-size: .9rem; color: #60728a; }
.compact-guide { margin: 10px 0 14px; }
.compact-guide-text { margin: 0; font-size: .9rem; color: var(--muted); }

.check-stage { display: grid; grid-template-columns: 1fr 1fr; grid-template-areas: "quick quick" "result result" "panel card" "saved saved"; gap: 16px; margin: 14px 0 28px; }
.quick-paste-panel { grid-area: quick; background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 14px; }
.quick-paste-panel h2 { margin: 0 0 4px; font-size: 1.08rem; }
.quick-paste-panel p { margin: 0 0 10px; color: var(--muted); font-size: .92rem; }
.quick-check-button { width: 100%; margin-top: 2px; }
.usage-chip { margin-bottom: 8px; display: inline-block; border-radius: 999px; background: #133a63; color: #fff; padding: 5px 12px; font-size: .82rem; font-weight: 700; }
.focus-card { margin-bottom: 10px; border: 1px solid #dce8f8; border-radius: 10px; padding: 10px; background: #f5f9ff; font-size: .87rem; color: #2c4b70; }
.initial-result-guide { border: 1px solid #eadfca; border-radius: 12px; background: #fff; padding: 10px; }
.extracted-card { margin-top: 10px; border: 1px solid #dbe5f5; border-radius: 12px; padding: 12px; background: #f8fbff; }
.extracted-card h3 { margin: 0 0 8px; font-size: .95rem; }
.extracted-empty { margin: 0; color: #5f6f86; font-size: .9rem; }
.extracted-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.extract-item { background: #fff; border: 1px solid #dbe5f5; border-radius: 10px; padding: 8px; }
.extract-item dt { font-size: .74rem; color: #5f6f86; font-weight: 700; }
.extract-item dd { margin: 2px 0 0; font-size: .88rem; font-weight: 700; }
.extract-unknown { border-color: #e7d3b2; background: #fff8ef; }
.listing-card { grid-area: card; background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 16px; display: grid; grid-template-columns: 1fr; gap: 12px; align-content: start; }
.listing-card-title { grid-column: 1 / -1; margin: 0 0 4px; font-size: 1.02rem; }
.is-hidden { display: none; }
.flash-change { animation: flashChange 0.95s ease; }
@keyframes flashChange {
  0% { box-shadow: 0 0 0 0 rgba(39, 96, 160, 0.35); }
  100% { box-shadow: 0 0 0 10px rgba(39, 96, 160, 0); }
}
.listing-price { margin: 0; font-size: clamp(1.8rem, 4vw, 2.4rem); font-weight: 900; color: #bc451e; }
.tag-row { display: flex; flex-wrap: wrap; gap: 7px; }
.tag { border: 1px solid #d7dfeb; background: #f8fbff; border-radius: 999px; padding: 5px 10px; font-size: .82rem; }
.tag-danger { background: #ffe8e8; border-color: #f0b9b9; color: #892828; }
.tag-warning { background: #fff4e3; border-color: #f0d1a0; color: #7a581f; }
.badge { display: inline-block; border-radius: 999px; padding: 5px 10px; font-size: .78rem; font-weight: 700; }
.badge-warning { background: #fff4df; color: #754d16; }
.badge-row { display: flex; gap: 6px; flex-wrap: wrap; }

.hero-check-button { border: 0; border-radius: 14px; padding: 13px 16px; font: inherit; font-weight: 800; color: #fff; background: linear-gradient(135deg, #162a45 0%, #264f7f 100%); cursor: pointer; }
.detail-check-button { width: 100%; margin-top: 4px; }
.editor-panel { grid-area: panel; border: 1px solid var(--line); border-radius: 18px; background: #fcfdff; padding: 14px; }
.details-panel details { margin-top: 6px; }
.details-panel summary { cursor: pointer; font-weight: 700; color: #294a73; margin-bottom: 8px; }
.editor-panel h2 { margin: 0 0 2px; font-size: 1.06rem; }
.editor-panel > p { margin: 0 0 10px; color: var(--muted); font-size: .9rem; }
.panel-section { border: 1px solid #e4e9f2; border-radius: 14px; background: #fff; padding: 10px; margin-bottom: 10px; }
.panel-section h3 { margin: 0 0 8px; font-size: .95rem; }
.input, select, textarea { width: 100%; padding: 10px; border: 1px solid #cfd8e6; border-radius: 10px; font: inherit; }
.form-row { margin-bottom: 10px; }
label { display: block; font-weight: 700; font-size: .85rem; margin-bottom: 4px; }

.purchase-result { grid-area: result; border-radius: 18px; border: 2px solid #d7c08d; background: linear-gradient(180deg, #fff9ec 0%, #fffef9 100%); padding: 16px; box-shadow: 0 6px 18px rgba(120, 88, 23, 0.08); }
.result-header { display: flex; justify-content: space-between; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.decision { border: 1px solid #eadfca; background: #fff; border-radius: 12px; padding: 12px; margin: 10px 0; }
.decision-text { margin: 0; font-size: 1.5rem; font-weight: 900; }
.final-check-card { border: 1px solid #eadfcb; border-radius: 12px; background: #fff; padding: 12px; margin: 10px 0; }
.compare-after-check-card { border-color: #d5e2f0; background: #f9fcff; }
.compare-after-check-card p { margin: 0 0 10px; color: #4f6380; }
.result-action-row { display: flex; flex-wrap: wrap; gap: 8px; }
.result-action-row .button { border: 0; cursor: pointer; }
.result-card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.good-card { border-color: #c5e3d0; background: #f5fcf7; }
.risk-card { border-color: #efd0c2; background: #fff7f3; }
.reason-list { margin: 8px 0 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.reason-list li { display: grid; grid-template-columns: auto 1fr; gap: 8px; align-items: flex-start; border: 1px solid #eef1f6; border-radius: 10px; padding: 8px; }
.reason-chip { display: inline-block; border-radius: 999px; padding: 3px 8px; font-size: .74rem; font-weight: 700; border: 1px solid #d7deea; background: #f8fbff; color: #2e4b6f; white-space: nowrap; }
.reason-good { border-color: #b7dfc7; background: #edf9f2; color: #1f6a42; }
.reason-warn { border-color: #efd8a8; background: #fff6e7; color: #8a6119; }
.reason-danger { border-color: #edc1c1; background: #fff0f0; color: #9a2f2f; }
.list { margin: 8px 0 0; padding-left: 18px; }
.risk-category-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.risk-category-card { border: 1px solid #eadfcb; border-radius: 10px; padding: 10px; background: #fffdf8; }
.risk-category-card h5 { margin: 0 0 6px; font-size: .92rem; }
.suitability-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
.suitability-item { border: 1px solid #e1e8f3; border-radius: 10px; padding: 9px; background: #fbfdff; }
.suitability-item strong { display: block; color: #1c385c; }
.suitability-item span { display: inline-block; margin: 4px 0; border-radius: 999px; padding: 2px 8px; font-size: .74rem; font-weight: 800; }
.suitability-good { background: #eaf8ef; color: #1c7145; }
.suitability-warn { background: #fff4df; color: #805511; }
.suitability-bad { background: #ffeded; color: #923030; }
.suitability-item p { margin: 2px 0 0; font-size: .86rem; color: #5f6f86; }
.saved-section { border-radius: 16px; border: 1px solid var(--line); background: #fff; padding: 14px; }
#savedSection { grid-area: saved; }
.article-links, .monetization-links, .next-choice-links { grid-column: 1 / -1; }
.affiliate-cta { margin: 10px 0; border: 1px solid #d9e2ef; border-radius: 12px; padding: 12px; background: #fdfefe; }
.affiliate-note { margin: 0; color: #3d4f68; font-size: .92rem; }
.affiliate-meta { margin: 8px 0 10px; font-size: .76rem; color: #6b7d92; font-weight: 700; letter-spacing: .02em; }
.affiliate-button { width: 100%; text-align: center; }
.result-affiliate-card {
  margin-top: 12px;
  border: 1px solid #cddcee;
  background: linear-gradient(180deg, #f9fcff 0%, #f4f8ff 100%);
  box-shadow: 0 7px 16px rgba(30, 62, 105, 0.1);
  opacity: 0;
  transform: translateY(6px);
  animation: fadeInCta 320ms ease-out forwards;
}
.affiliate-pr-badge {
  display: inline-block;
  border-radius: 999px;
  border: 1px solid #b8cbdf;
  background: #eef4fb;
  color: #3d5878;
  font-size: .68rem;
  font-weight: 800;
  line-height: 1.2;
  padding: 2px 8px;
}
.affiliate-subnote {
  margin: 8px 0 0;
  color: #4c6381;
  font-size: .9rem;
}
.pcwrap-cta-button {
  margin-top: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
  box-shadow: 0 6px 12px rgba(17, 49, 86, 0.18);
}
.pcwrap-cta-button:hover {
  text-decoration: none;
  transform: translateY(-1px);
  filter: brightness(1.03);
  box-shadow: 0 10px 18px rgba(17, 49, 86, 0.24);
}
.pcwrap-cta-button:active {
  transform: translateY(1px);
  box-shadow: 0 4px 10px rgba(17, 49, 86, 0.2);
}
@keyframes fadeInCta {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.article-affiliate-cta { margin: 14px 0 12px; border: 1px solid #d8e3f0; border-radius: 12px; background: #f9fbff; padding: 12px; }
.article-affiliate-cta p { margin: 0; color: #4f6280; font-size: .92rem; }
.article-affiliate-cta .affiliate-meta { margin-top: 8px; }
.article-affiliate-cta .button { margin-top: 10px; }
.saved-head { display: flex; gap: 10px; justify-content: space-between; align-items: center; flex-wrap: wrap; }
.saved-head h2 { margin: 0; font-size: 1.1rem; }
.saved-count { border: 1px solid #cfe0f4; border-radius: 999px; background: #f2f8ff; color: #25476c; font-size: .82rem; font-weight: 800; padding: 4px 10px; }
.save-button { border: 0; cursor: pointer; }
.delete-candidate { border: 1px solid #d8dfea; border-radius: 8px; background: #fff; padding: 6px 10px; cursor: pointer; }
.saved-table-wrap { overflow-x: auto; }

.article { padding: 14px 0 24px; }
.article h1 { font-size: clamp(1.4rem, 3vw, 1.9rem); margin-bottom: 10px; }
.lead-box { border: 1px solid #d8e3f3; border-radius: 12px; background: #f5f9ff; padding: 12px; margin-bottom: 12px; }
.conclusion-card { border: 1px solid #cfe0f4; border-radius: 12px; background: #f2f8ff; padding: 12px; }
.notice-box { border: 1px solid #f0d3a4; border-radius: 12px; background: #fff7eb; padding: 12px; margin: 12px 0; }
.okng-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin: 10px 0; }
.ok-card, .ng-card { border-radius: 10px; padding: 10px; border: 1px solid; }
.ok-card { border-color: #b9dfcb; background: #f1fcf5; }
.ng-card { border-color: #efc3c3; background: #fff3f3; }
.question-copy { width: 100%; border: 1px solid #d7deea; border-radius: 10px; padding: 10px; background: #f8fbff; font: inherit; }
.template-box { border: 1px solid #d7deea; border-radius: 12px; padding: 12px; background: #f8fbff; margin: 12px 0; }
.template-box-label { display: inline-block; margin: 0 0 8px; border: 1px solid #cddcee; border-radius: 999px; background: #fff; color: #365475; font-size: .78rem; font-weight: 800; padding: 3px 9px; }
.template-box pre { margin: 0; white-space: pre-wrap; overflow-wrap: anywhere; font: inherit; color: #233955; line-height: 1.75; }
.article-check-cta { border: 1px solid #d8e4f2; border-radius: 12px; background: #fff; padding: 12px; margin: 14px 0; }
.article-check-links { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.article-check-links a { font-size: .92rem; }
.table-scroll { overflow-x: auto; margin-top: 10px; }
.table-scroll .compare-table { margin-top: 0; }
.compare-table { width: 100%; min-width: 760px; border-collapse: collapse; margin-top: 10px; background: #fff; }
.compare-table th, .compare-table td { border: 1px solid #dce4f2; padding: 9px; text-align: left; vertical-align: top; }
.compare-table th { background: #f5f9ff; color: #203d5f; white-space: nowrap; }
.compare-table td { font-size: .9rem; }
.related-grid { display: grid; gap: 10px; grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top: 12px; }
.related-card { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 10px; display: grid; gap: 4px; }
.related-card strong { color: #18395f; }
.related-card span { color: #5d7088; font-size: .88rem; }
.affiliate-slot { position: relative; }
.affiliate-slot::after { content: "PR枠"; position: absolute; right: 10px; top: 10px; font-size: .7rem; color: #607892; }
.affiliate-slot-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 10px; }
.affiliate-action-card { display: grid; gap: 6px; border: 1px solid #d4e0ef; border-radius: 12px; background: #fff; padding: 12px; color: #213d60; }
.affiliate-action-card:hover { text-decoration: none; border-color: #adc6e3; }
.affiliate-action-card span { color: #5a708a; font-size: .88rem; }
.privacy-note { color: #60728a; font-size: .86rem; margin: 8px 0; }
.save-status { display: none; border: 1px solid #b8d9c7; background: #f2fbf5; border-radius: 12px; padding: 10px; margin: 10px 0; color: #1f613d; font-weight: 700; }
.save-status:not(:empty) { display: block; }
.save-status-warning { border-color: #e8c48b; background: #fff8ea; color: #805511; }
.recommend-card { border: 1px solid #bddcc8; background: #f2fbf5; border-radius: 12px; padding: 10px; margin: 10px 0; color: #1f613d; }
.recommend-card span { display: block; margin-top: 4px; color: #315f45; font-size: .92rem; }
.empty-compare-card { border: 1px solid #dce6f3; background: #f8fbff; border-radius: 12px; padding: 12px; color: #2f4b6d; }
.empty-compare-card p { margin: 4px 0 0; color: #60728a; font-size: .9rem; }
.best-row { background: #f3fbf6; }
.note-chip { display: block; border: 1px solid #e1e8f3; border-radius: 8px; background: #fbfdff; padding: 4px 7px; margin: 0 0 5px; color: #405775; }
.saved-actions { margin-top: 10px; }
.category-block { margin: 14px 0; }
.cta-box { margin-top: 20px; border: 1px solid #d5dfef; border-radius: 14px; padding: 16px; background: #fff; text-align: center; }
.cta-box .button { font-size: 1rem; padding: 13px 18px; }

.site-footer { margin-top: 24px; border-top: 1px solid var(--line); background: #fff; }
.footer-row { padding: 16px 0 22px; font-size: .9rem; color: var(--muted); }

@media (max-width: 960px) {
  .grid-3, .related-grid, .risk-category-grid, .extracted-grid, .steps-grid, .okng-grid, .use-grid, .result-card-grid, .suitability-grid, .affiliate-slot-grid { grid-template-columns: 1fr; }
  .hero-split { grid-template-columns: 1fr; }
  .check-stage { grid-template-columns: 1fr; grid-template-areas: "quick" "result" "panel" "card" "saved"; }
  .card, .panel-section, .final-check-card, .quick-paste-panel { padding: 12px; }
  .article { padding-bottom: 18px; }
  .purchase-result { padding: 12px; border-width: 1px; }
  .decision-text { font-size: 1.32rem; line-height: 1.3; }
  .result-header { font-size: .92rem; }
  .reason-list li { grid-template-columns: 1fr; }
  .copy-text { min-height: 150px; }
  .compare-table { min-width: 680px; }
  .affiliate-button { min-height: 48px; display: inline-flex; justify-content: center; align-items: center; }
  .result-affiliate-card .affiliate-note br { display: none; }
}

@media (prefers-color-scheme: dark) {
  .result-affiliate-card {
    border-color: #3f4f67;
    background: linear-gradient(180deg, #222f42 0%, #1c2738 100%);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.28);
  }
  .result-affiliate-card .affiliate-note,
  .result-affiliate-card .affiliate-subnote,
  .result-affiliate-card .affiliate-meta {
    color: #d9e7fb;
  }
  .result-affiliate-card .affiliate-pr-badge {
    border-color: #5f7696;
    background: #30435c;
    color: #ecf4ff;
  }
}

.copy-text { width: 100%; border: 1px solid #d7deea; border-radius: 10px; padding: 10px; font: inherit; background: #f8fbff; margin-bottom: 8px; }
.highlight-box { border: 1px solid #eadfcb; border-radius: 10px; background: #fff; padding: 10px; max-height: 260px; overflow: auto; font-size: .9rem; line-height: 1.7; }
.risk-mark { background: #ffe3e3; color: #7c1e1e; border-radius: 4px; padding: 0 2px; font-weight: 700; }
.hero-actions .button { border: 0; cursor: pointer; }

.home-main { overflow: hidden; }
.home-hero-wrap {
  padding: 68px 0 44px;
  background:
    radial-gradient(circle at 82% 12%, rgba(31, 68, 119, 0.15) 0%, rgba(31, 68, 119, 0) 46%),
    linear-gradient(160deg, #f9fbff 0%, #edf3fb 52%, #e9f0f8 100%);
}
.home-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}
.hero-kicker {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  background: #e6effa;
  color: #1f4c80;
  border: 1px solid #cddcf0;
  font-size: .77rem;
  font-weight: 700;
  letter-spacing: .04em;
}
.home-hero-copy h1 {
  margin: 14px 0 18px;
  font-size: clamp(2rem, 4.4vw, 3.3rem);
  line-height: 1.2;
  letter-spacing: .01em;
  color: #122845;
}
.home-hero-copy p {
  margin: 0;
  max-width: 56ch;
  color: #415773;
  font-size: 1rem;
}
.hero-actions { margin-top: 22px; }
.home-hero-copy .button { padding: 13px 20px; border-radius: 14px; }
.home-hero-copy .button-sub { background: linear-gradient(135deg, #2f4f77 0%, #50739d 100%); }
.hero-meta { margin-top: 14px; font-size: .84rem; color: #5d728d; font-weight: 600; }

.hero-panel {
  border: 1px solid #cfdbec;
  background: linear-gradient(160deg, #ffffff 0%, #f3f7fd 100%);
  border-radius: 24px;
  padding: 22px;
  box-shadow: 0 20px 36px rgba(25, 53, 90, 0.16);
  display: grid;
  gap: 12px;
}
.hero-panel-head { display: flex; justify-content: space-between; align-items: center; }
.hero-live {
  font-size: .75rem;
  letter-spacing: .06em;
  color: #1d6e45;
  background: #e8f8ef;
  border: 1px solid #cbe9d7;
  padding: 3px 8px;
  border-radius: 999px;
  font-weight: 700;
}
.hero-product-card {
  border: 1px solid #d6e3f4;
  border-radius: 14px;
  padding: 12px;
  background: #f8fbff;
}
.hero-product-title { margin: 0 0 4px; color: #58708f; font-size: .8rem; }
.hero-product-card strong { color: #223e62; font-size: .95rem; line-height: 1.5; }
.hero-result-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: center;
  border: 1px solid #d8e4f4;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}
.hero-result-row p { margin: 0 0 2px; font-size: .8rem; color: #5f7692; }
.hero-result-row strong { font-size: 1.05rem; color: #17365a; }
.hero-score {
  text-align: center;
  min-width: 72px;
  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid #cce0f5;
  background: #eef6ff;
}
.hero-score span { display: block; font-size: .72rem; color: #44658b; }
.hero-score strong { font-size: 1.2rem; color: #134277; }
.hero-chip-grid { display: flex; flex-wrap: wrap; gap: 7px; }
.hero-question-box {
  border: 1px solid #dbe6f5;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}
.hero-question-box p { margin: 0 0 4px; font-size: .78rem; color: #607892; }
.hero-question-box strong { color: #1f3c62; font-size: .9rem; }

.home-section { padding: 74px 0; }
.home-section-soft {
  background: linear-gradient(180deg, rgba(248, 251, 255, 0.96) 0%, rgba(238, 244, 252, 0.92) 100%);
  border-top: 1px solid #dce6f4;
  border-bottom: 1px solid #dce6f4;
}
.section-head { max-width: 720px; margin-bottom: 26px; }
.section-head span {
  display: inline-block;
  font-size: .74rem;
  letter-spacing: .08em;
  color: #4f6683;
  font-weight: 700;
}
.section-head h2 {
  margin: 10px 0 0;
  font-size: clamp(1.5rem, 3.4vw, 2.35rem);
  line-height: 1.3;
  color: #102a4a;
}

.home-feature-section { background: #fff; }
.feature-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.feature-card {
  background: linear-gradient(165deg, #ffffff 0%, #f5f9ff 100%);
  border: 1px solid #d6e2f3;
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 10px 20px rgba(33, 61, 101, 0.08);
}
.feature-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: #e7f0fb;
  color: #1a487d;
  font-size: .74rem;
  font-weight: 800;
}
.feature-card h3 { margin: 10px 0 6px; font-size: 1.02rem; color: #17365c; }
.feature-card p { margin: 0; color: #536984; font-size: .9rem; }

.steps-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.step-card {
  border: 1px solid #d5e0ef;
  border-radius: 16px;
  background: #fff;
  padding: 18px;
  box-shadow: 0 10px 20px rgba(34, 61, 95, 0.08);
}
.step-no {
  display: inline-block;
  font-size: .7rem;
  letter-spacing: .06em;
  background: #eaf2ff;
  color: #1f4b7e;
  padding: 4px 9px;
  border-radius: 999px;
}
.step-card h3 { margin: 10px 0 6px; color: #17365b; }
.step-card p { margin: 0; color: #5a6f8a; font-size: .9rem; }

.risk-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.risk-board-card {
  border: 1px solid #d6e1f2;
  border-radius: 16px;
  background: linear-gradient(165deg, #ffffff 0%, #f6faff 100%);
  padding: 18px;
  box-shadow: 0 10px 20px rgba(36, 61, 99, 0.07);
}
.risk-board-card h3 { margin: 0 0 10px; color: #16365d; font-size: 1rem; }
.risk-board-card ul { margin: 0; padding-left: 18px; color: #3f5573; }
.risk-board-card p { margin: 0; color: #4d6380; font-size: .92rem; }
.risk-level {
  display: inline-block;
  margin: 0 0 8px;
  font-weight: 800;
  color: #8a5a18;
  background: #fff3df;
  border: 1px solid #efd3a8;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: .78rem;
}

.use-hint { margin: 0 0 14px; color: #5a708b; font-size: .95rem; }
.usecase-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 12px; }
.usecase-card {
  border: 1px solid #cfddf0;
  border-radius: 14px;
  background: linear-gradient(170deg, #fff 0%, #f3f8ff 100%);
  padding: 14px 12px;
  display: grid;
  gap: 6px;
  text-align: left;
  box-shadow: 0 8px 16px rgba(29, 57, 96, 0.06);
}
.usecase-card:hover { text-decoration: none; border-color: #b4cbe7; transform: translateY(-2px); }
.usecase-card strong { color: #18395f; font-size: .94rem; }
.usecase-card span { color: #5d7290; font-size: .82rem; line-height: 1.45; }

.home-cta-band {
  padding: 74px 0 78px;
  background: linear-gradient(150deg, #102745 0%, #1f416a 50%, #2b5a8c 100%);
  color: #fff;
}
.home-cta-inner { text-align: center; }
.home-cta-inner p {
  margin: 0;
  display: inline-block;
  border: 1px solid rgba(255, 255, 255, 0.32);
  border-radius: 999px;
  padding: 5px 10px;
  font-size: .76rem;
  letter-spacing: .05em;
}
.home-cta-inner h2 {
  margin: 14px 0 20px;
  font-size: clamp(1.6rem, 3.7vw, 2.4rem);
  line-height: 1.35;
}
.home-cta-inner .button {
  background: #fff;
  color: #13355d;
  border-radius: 999px;
  padding: 13px 24px;
  box-shadow: 0 10px 22px rgba(8, 20, 39, 0.33);
}

@media (max-width: 960px) {
  .home-hero {
    grid-template-columns: 1fr;
    gap: 22px;
  }
  .home-hero-wrap { padding: 34px 0 28px; }
  .feature-grid, .steps-grid, .risk-board, .usecase-grid { grid-template-columns: 1fr; }
  .home-section { padding: 44px 0; }
  .home-hero-copy h1 br { display: none; }
  .hero-meta { margin-top: 12px; }
  .hero-actions { margin-top: 18px; }
  .home-cta-band { padding: 50px 0 56px; }
}

.compare-promo, .home-compare-band { border: 1px solid #cdddf0; background: linear-gradient(135deg, #f7fbff 0%, #eef6ff 100%); }
.compare-promo { display: grid; gap: 8px; margin: 14px 0 18px; padding: 16px; border-radius: 14px; }
.compare-promo strong { color: #16365f; font-size: 1.05rem; }
.compare-promo p { margin: 0; color: #4d617d; }
.compare-promo-subtle { margin: 10px 0 12px; padding: 10px 12px; background: #fff; border-color: #dbe5f1; }
.compare-promo-subtle p { font-size: .9rem; }
.compare-promo-subtle .text-link { font-size: .88rem; justify-self: start; }
.sample-button-group { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin-top: 10px; }
.sample-input-button { width: 100%; min-height: 44px; }
.saved-section-strong { border-color: #b9d2ee; box-shadow: 0 12px 28px rgba(30, 74, 122, .09); }
.feature-card-strong { border-color: #b9d2ee; background: #f8fbff; }
.home-compare-band { padding: 34px 0; }
.home-compare-inner { display: grid; gap: 10px; text-align: center; justify-items: center; }
.home-compare-inner strong { color: #17365c; font-size: clamp(1.25rem, 3vw, 1.75rem); }
.home-compare-inner p { max-width: 720px; margin: 0; color: #4d617d; }
@media (max-width: 760px) { .sample-button-group { grid-template-columns: 1fr; } }
