:root{
  --blue-900:#0f3a5f;
  --blue-700:#1d6099;
  --blue-600:#1f6cae;
  --blue-500:#2f87c4;
  --teal:#1c93b8;
  --teal-dark:#16809f;
  --ink:#2c333b;
  --ink-soft:#5b636c;
  --line:#e2e8ee;
  --line-strong:#d3dce4;
  --bg:#ffffff;
  --bg-soft:#f6f9fc;
  --link:#1565a8;
  --maxw:1080px;
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo",sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--link);text-decoration:none;}
a:hover{text-decoration:underline;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
img{max-width:100%;display:block;}

.site-header{border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:50;}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:14px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.brand{font-size:16px;font-weight:700;color:var(--blue-700);letter-spacing:.02em;}
.brand a{color:inherit;}
.brand a:hover{text-decoration:none;}
.gnav{display:flex;gap:22px;align-items:center;}
.gnav a{font-size:14px;font-weight:500;color:var(--ink);}
.gnav a:hover{color:var(--blue-700);text-decoration:none;}
.gnav-cta{
  background:var(--blue-700);color:#fff !important;
  padding:9px 18px;border-radius:6px;font-size:13.5px;
}
.gnav-cta:hover{background:var(--blue-600);}
.hamburger{
  display:none;background:none;border:0;cursor:pointer;
  width:42px;height:42px;padding:0;position:relative;
}
.hamburger span{
  display:block;position:absolute;left:9px;right:9px;height:2px;background:var(--ink);
  border-radius:2px;transition:transform .25s,opacity .2s,top .25s;
}
.hamburger span:nth-child(1){top:13px;}
.hamburger span:nth-child(2){top:20px;}
.hamburger span:nth-child(3){top:27px;}
.hamburger.open span:nth-child(1){top:20px;transform:rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){top:20px;transform:rotate(-45deg);}

.breadcrumb-bar{background:var(--bg-soft);border-bottom:1px solid var(--line);}
.breadcrumb{
  max-width:var(--maxw);margin:0 auto;padding:12px 24px;
  font-size:12.5px;color:var(--ink-soft);
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
}
.breadcrumb .sep{color:#aab4bd;font-size:11px;}
.breadcrumb a{color:var(--ink-soft);}
.breadcrumb .current{color:var(--ink);font-weight:500;}

.sec-head{
  display:flex;align-items:center;gap:12px;
  font-size:24px;font-weight:700;color:var(--ink);
  margin:0 0 28px;
}
.sec-head::before{
  content:"";width:6px;height:26px;border-radius:2px;
  background:var(--blue-600);flex:none;
}
section{padding:64px 0;}

.hero{padding-top:48px;padding-bottom:56px;}
.hero-grid{display:grid;grid-template-columns:1fr 0.92fr;gap:32px;align-items:start;}
.hero h1{
  font-size:46px;line-height:1.2;font-weight:900;letter-spacing:.01em;
  margin:4px 0 18px;color:#1b2229;
}
.hero-lead{font-size:17px;font-weight:700;color:#222a31;margin:0 0 22px;line-height:1.65;}
.hero-body{font-size:15px;color:var(--ink-soft);margin:0 0 18px;line-height:1.85;}
.hero-note{font-size:13px;color:var(--ink-soft);margin:0;line-height:1.75;}
.hero-art{align-self:start;}
.hero-art img{width:100%;height:auto;}

.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px;}
table.compare{
  width:100%;min-width:760px;border-collapse:separate;border-spacing:0;
  background:#fff;font-size:13.5px;
}
table.compare thead th{
  background:var(--blue-700);color:#fff;font-weight:700;
  padding:14px 14px;text-align:center;line-height:1.5;font-size:13px;
  border-right:1px solid rgba(255,255,255,.18);
}
table.compare thead th:first-child{border-top-left-radius:8px;}
table.compare thead th:last-child{border-top-right-radius:8px;border-right:none;}
table.compare tbody td{
  padding:18px 14px;border-bottom:1px solid var(--line);
  text-align:center;vertical-align:middle;color:var(--ink);
}
table.compare tbody tr:last-child td{border-bottom:1px solid var(--line-strong);}
.col-name{text-align:left;min-width:170px;}
.col-name .cname{font-weight:700;font-size:14.5px;color:#1b2229;}
.col-name .caddr{font-size:12.5px;color:var(--ink-soft);margin-top:3px;}
.badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-start;}
td.col-tags{min-width:200px;}
.col-found .yr{font-weight:500;}
.col-found .exp{font-size:12.5px;color:var(--ink-soft);}
.rating{display:flex;align-items:center;justify-content:center;gap:5px;font-weight:700;font-size:16px;color:#1b2229;}
.rating .star{color:#f5a623;font-size:16px;}
.rating-cnt{font-size:12.5px;color:var(--ink-soft);margin-top:2px;}

.badge{
  display:inline-flex;align-items:center;
  padding:3px 9px;border-radius:5px;font-size:11.5px;font-weight:500;
  line-height:1.3;white-space:nowrap;
}
.b-chumon{background:#e4f0fb;color:#1c6fb0;}
.b-shizen{background:#d8efe7;color:#1c8b78;}
.b-taishin{background:#fbeede;color:#c9741a;}
.b-reform{background:#e4f3e1;color:#3a8a3f;}
.b-zoukai{background:#def0f5;color:#1f86a8;}
.b-tenpo{background:#ece6f5;color:#7a5aa8;}
.b-niseta{background:#d9eff0;color:#1d8a93;}
.b-shoene{background:#e4f3e1;color:#3a8a3f;}
.b-sekkei{background:#ecf0f3;color:#5a6470;}

.btn-official{
  display:inline-flex;align-items:center;gap:6px;justify-content:center;
  background:var(--teal);color:#fff;border-radius:6px;
  padding:8px 12px;font-size:12.5px;font-weight:500;white-space:nowrap;
}
.btn-official:hover{background:var(--teal-dark);text-decoration:none;color:#fff;}
.btn-detail{
  display:inline-flex;align-items:center;gap:8px;justify-content:space-between;
  background:#fff;color:var(--blue-700);border:1px solid var(--blue-700);
  border-radius:6px;padding:8px 14px;font-size:12.5px;font-weight:500;white-space:nowrap;
}
.btn-detail:hover{background:#f0f6fc;text-decoration:none;}
.table-note{font-size:12px;color:var(--ink-soft);margin:14px 0 0;}

.firm{
  display:grid;grid-template-columns:300px 1fr;gap:28px;align-items:start;
  border:1px solid var(--line);border-radius:10px;padding:22px;
  margin-bottom:20px;background:#fff;
}
.firm-photo{
  position:relative;
  aspect-ratio:4/3;border-radius:8px;overflow:hidden;
  border:1px solid var(--line-strong);background:#fff;
  display:flex;align-items:center;justify-content:center;
}
.firm-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;}
.firm-photo .firm-photo-label{
  position:absolute;left:8px;bottom:8px;
  background:rgba(15,58,95,.85);color:#fff;
  font-size:11px;font-weight:500;letter-spacing:.04em;
  padding:3px 9px;border-radius:4px;
}
.firm-photo.no-img{
  background:repeating-linear-gradient(45deg,#eef1f4 0 12px,#e7ebef 12px 24px);
}
.firm-photo.no-img .firm-photo-label{
  background:transparent;color:#9aa6b0;
  position:static;font-family:"SFMono-Regular",ui-monospace,Menlo,Consolas,monospace;
  font-size:12px;letter-spacing:.04em;padding:0;
}
.firm-photo.no-img .firm-photo-label::before{content:"公式サイト画像（準備中）";}
.firm-photo.no-img .firm-photo-label{font-size:0;}
.firm-photo.no-img .firm-photo-label::before{font-size:12px;}
.firm-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px;}
.firm-body{padding-top:2px;}
.firm-head{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:14px;}
.firm-name{font-size:20px;font-weight:700;color:#1b2229;margin:0;line-height:1.4;}
.firm-text{font-size:14.5px;color:#3c444c;margin:0;line-height:1.85;}

.firms-hidden{display:none;}
.firms-hidden.is-open{display:block;}
.more-row{display:flex;justify-content:center;margin:24px 0 0;}
.btn-more{
  display:inline-flex;align-items:center;gap:12px;justify-content:center;
  background:#fff;color:var(--blue-700);border:1px solid var(--blue-500);
  border-radius:8px;padding:15px 48px;font-size:15px;font-weight:500;cursor:pointer;
  font-family:inherit;transition:background .2s;
}
.btn-more:hover{background:#f0f6fc;}
.btn-more .chev{transition:transform .25s;}
.btn-more.open .chev{transform:rotate(180deg);}

.points-text p{font-size:15px;color:#3c444c;margin:0 0 10px;line-height:1.9;}
.points-lead{font-size:15px;color:#3c444c;margin:0 0 28px;line-height:1.9;}
.points-icons{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;
  margin-bottom:40px;
}
.point{
  display:flex;align-items:center;gap:10px;
  flex:1 1 0;min-width:0;justify-content:center;
  padding:14px 4px;border-right:1px dashed var(--line-strong);
  color:var(--ink);transition:background .2s;
  border-radius:4px;
}
.point:hover{background:#f1f7fc;text-decoration:none;}
.point:last-child{border-right:none;}
.point svg{width:34px;height:34px;flex:none;stroke:var(--blue-600);}
.point .plabel{font-size:13.5px;font-weight:500;color:#2c333b;white-space:nowrap;}

.points-detail{display:flex;flex-direction:column;gap:28px;}
.point-block{
  background:#fff;border:1px solid var(--line);border-radius:10px;
  padding:24px 28px;
  scroll-margin-top:90px;
}
.point-h{
  font-size:18px;font-weight:700;color:#1b2229;
  margin:0 0 12px;padding-left:12px;
  border-left:4px solid var(--blue-600);line-height:1.4;
}
.point-block p{font-size:15px;color:#3c444c;margin:0;line-height:1.95;}

.info-banner{
  border:1px solid #bcd6ec;background:#f1f7fc;border-radius:8px;
  padding:20px 24px;text-align:center;font-size:14.5px;color:#2c333b;line-height:1.8;
}
.info-banner .ext{color:var(--ink-soft);font-size:12px;}

.faq-item{border:1px solid var(--line-strong);border-radius:8px;margin-bottom:12px;background:#fff;overflow:hidden;}
.faq-q{
  width:100%;display:flex;align-items:center;gap:14px;
  background:none;border:none;cursor:pointer;font-family:inherit;
  padding:18px 22px;text-align:left;font-size:15px;font-weight:500;color:#2c333b;
}
.faq-q .q-mark{color:var(--blue-600);font-weight:700;font-size:15px;flex:none;}
.faq-q .q-text{flex:1;}
.faq-q .q-toggle{font-size:22px;color:var(--blue-600);font-weight:400;line-height:1;flex:none;transition:transform .2s;}
.faq-item.open .q-toggle{transform:rotate(45deg);}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .3s ease;
  color:#3c444c;font-size:14.5px;line-height:1.95;
}
.faq-a .faq-a-inner{padding:0 22px 20px 50px;}
.faq-placeholder{color:#9aa6b0;font-style:normal;}

.site-footer{
  background:linear-gradient(180deg,#2173b3 0%,#1c66a6 100%);
  color:#fff;margin-top:40px;padding:48px 0 28px;
}
.footer-cols{
  display:grid;grid-template-columns:repeat(5,1fr);gap:18px;
  text-align:center;
}
.footer-cols a{color:#fff;font-size:14px;font-weight:700;}
.footer-cols .fcol .fsub{font-size:18px;color:#cfe4f4;margin-top:6px;line-height:1;}
.footer-mid{
  display:flex;justify-content:center;flex-wrap:wrap;gap:26px;
  margin-top:28px;padding-top:6px;
}
.footer-mid a{color:#eaf3fb;font-size:13px;}
.footer-copy{text-align:center;margin-top:20px;font-size:12.5px;color:#cfe4f4;}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal.is-visible{opacity:1;transform:translateY(0);}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

@media (max-width:880px){
  .hero h1{font-size:38px;}
}
@media (max-width:768px){
  .hamburger{display:block;}
  .gnav{
    position:absolute;top:100%;right:0;left:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:#fff;border-top:1px solid var(--line);
    box-shadow:0 4px 14px rgba(0,0,0,.06);
    max-height:0;overflow:hidden;transition:max-height .3s ease;
  }
  .gnav.is-open{max-height:420px;}
  .gnav a{padding:14px 24px;border-bottom:1px solid var(--line);font-size:15px;}
  .gnav-cta{margin:14px 24px;text-align:center;}
  .header-inner{position:relative;}
  .hero-grid{grid-template-columns:1fr;gap:18px;}
  .hero-art{max-width:460px;margin:0 auto;order:-1;}
  .hero h1{font-size:32px;}
  section{padding:48px 0;}
  .firm{grid-template-columns:1fr;gap:18px;}
  .firm-photo{max-width:none;}
  .point{flex:1 1 40%;border-right:none;justify-content:flex-start;}
  .footer-cols{grid-template-columns:repeat(2,1fr);gap:18px 14px;text-align:left;}
  .footer-cols a{font-size:13.5px;}
}
@media (max-width:480px){
  .wrap{padding:0 16px;}
  .header-inner{padding:12px 16px;}
  .breadcrumb{padding:11px 16px;}
  .hero h1{font-size:27px;}
  .sec-head{font-size:20px;}
  section{padding:40px 0;}
  .btn-more{padding:14px 24px;width:100%;}
  .point{flex:1 1 100%;}
}
