/* ===== Price page ===== */
.gnav a.is-active{color:var(--navy);font-weight:700}

/* info bar */
.pinfo{background:#eef2f8;border-bottom:1px solid #e0e6f0}
.pinfo__inner{
  max-width:var(--maxw);margin:0 auto;padding:12px 28px;
  display:flex;align-items:center;gap:10px;
}
.pinfo__inner svg{width:20px;height:20px;fill:#8a97ad;flex-shrink:0}
.pinfo__inner span{font-size:15px;font-weight:700;color:var(--navy)}

/* hero */
.phero{position:relative;overflow:hidden;background:#fff}
.phero__visual{
  position:absolute;top:0;right:0;z-index:1;
  width:60%;height:calc(100% - 128px);
}
.phero__visual>img{
  width:100%;height:100%;object-fit:cover;object-position:left bottom;
  -webkit-mask-image:linear-gradient(100deg,transparent 0%,#000 26%,#000 100%);
  mask-image:linear-gradient(100deg,transparent 0%,#000 26%,#000 100%);
}

/* navy price card */
.phero__card{
  position:absolute;top:26%;right:14%;z-index:2;
  width:380px;padding:36px 44px 30px;text-align:center;color:#fff;
  background:var(--navy);
  border:1px solid rgba(255,255,255,.35);
  clip-path:polygon(0 0, 100% 0, 100% 78%, 90% 100%, 0 100%);
  box-shadow:0 24px 50px rgba(12,35,80,.28);
}
.phero__card-cat{display:block;font-size:22px;font-weight:700;letter-spacing:2px;
  padding-bottom:18px;margin-bottom:22px;border-bottom:1px solid rgba(255,255,255,.4)}
.phero__card-price{display:block;font-size:48px;font-weight:900;letter-spacing:0;line-height:1;white-space:nowrap}
.phero__card-price b{font-size:34px;font-weight:900;margin-right:6px}
.phero__card-note{display:block;margin-top:18px;font-size:16px;color:rgba(255,255,255,.85)}

/* body / text column */
.phero__inner{position:relative;z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.phero__body{width:52%;max-width:620px;padding:64px 0 58px}
.phero__crumb{font-size:15px;color:var(--muted)}
.phero__crumb a{color:var(--muted)}
.phero__crumb a:hover{color:var(--navy)}
.phero__label{display:block;margin-top:20px;font-size:20px;font-weight:800;letter-spacing:3px;color:#2b5bb5}
.phero__title{margin-top:10px;font-size:72px;font-weight:900;color:var(--navy);letter-spacing:6px;line-height:1.1}
.phero__rule{display:block;width:64px;height:3px;background:#c7d0e0;margin:26px 0}
.phero__lead{font-size:18px;line-height:1.95;color:var(--text);font-weight:500}
.phero__btn{
  display:inline-flex;align-items:center;gap:16px;margin-top:34px;
  background:var(--navy);color:#fff;height:74px;padding:0 40px;border-radius:8px;
  font-size:21px;font-weight:700;transition:opacity .2s;
  box-shadow:0 14px 30px rgba(12,35,80,.22);
}
.phero__btn svg{width:26px;height:26px;fill:#fff}
.phero__btn .arr{font-style:normal;font-size:24px;margin-left:6px}
.phero__btn:hover{opacity:.92}
.phero__tel{display:flex;align-items:center;gap:10px;margin-top:24px;font-size:15px;color:var(--text);font-weight:500}
.phero__tel svg{width:20px;height:20px;fill:var(--navy);flex-shrink:0}
.phero__tel a{color:var(--navy);font-weight:700}

/* stats bar */
.phero__stats{
  position:relative;z-index:3;
  max-width:var(--maxw);margin:0 auto;padding:26px 28px 34px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;list-style:none;
  background:rgba(255,255,255,.86);
}
.phero__stats li{
  display:flex;align-items:center;gap:18px;padding:10px 26px;
}
.phero__stats li + li{border-left:1px solid #e3e8f0}
.phero__stat-ic{width:52px;height:52px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.phero__stat-ic img{width:100%;height:100%;object-fit:contain}
.phero__stat-txt{display:flex;flex-direction:column;gap:4px;font-size:15px;color:var(--muted)}
.phero__stat-txt b{font-size:20px;font-weight:800;color:var(--navy)}

/* ===== Comparison ===== */
.cmp{position:relative;overflow:hidden;background:#fff;padding:90px 0 84px}
.cmp__bg{
  position:absolute;inset:0;z-index:0;
  background:url("../assets/img/pr-cmp-bg.png") center top/cover no-repeat;
  opacity:.5;pointer-events:none;
}
.cmp__inner{position:relative;z-index:2;max-width:1120px;margin:0 auto;padding:0 28px;text-align:center}
.cmp__title{font-size:52px;font-weight:900;color:var(--navy);letter-spacing:8px;line-height:1.1}
.cmp__rule{display:block;width:46px;height:2px;background:#9fb0cc;margin:18px auto 12px}
.cmp__label{display:block;font-size:17px;font-weight:800;letter-spacing:3px;color:#2b5bb5}
.cmp__lead{margin-top:22px;font-size:17px;color:var(--text);font-weight:500}

.cmp__table{position:relative;margin-top:44px}
.cmp__grid{
  position:relative;display:grid;grid-auto-flow:column;
  grid-template-columns:0.92fr 1.5fr 1.05fr;
  grid-template-rows:auto repeat(5,1fr);
  border:1px solid #dbe2ee;border-radius:16px;overflow:hidden;
}
.cmp__grid>div{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:22px 20px;font-size:17px;line-height:1.5;
}
/* header row */
.cmp__grid .head{font-size:19px;font-weight:800;padding:22px 20px}
.c1.head{background:var(--navy);color:#fff}
.c2.head{background:#eef2f7;color:var(--navy)}
.c3.head{color:#fff}
/* body cells */
.c1{background:#f7f9fc;color:var(--navy);font-weight:700}
.c2{background:#fff;color:var(--muted);border-left:1px solid #e7ecf4}
.c3{color:#fff;font-weight:800;font-size:21px}
/* row separators */
.c1:not(.head),.c2:not(.head){border-top:1px solid #e7ecf4}
.c1.head{border-top:none}

/* floating navy highlight for 当サービス column */
.cmp__hl{
  position:absolute;top:-14px;bottom:-10px;right:0;width:30.4%;z-index:0;
  background:var(--navy);border-radius:16px;
  box-shadow:0 22px 46px rgba(12,35,80,.30);
}

.cmp__note{
  display:flex;align-items:center;justify-content:center;gap:12px;
  margin-top:34px;font-size:17px;font-weight:700;color:var(--navy);
}
.cmp__note img{width:26px;height:26px;flex-shrink:0}

/* ===== CTA / Contact ===== */
.cta{position:relative;overflow:hidden;background:#eef3fa;padding:92px 0 88px}
.cta__bg{
  position:absolute;inset:0;z-index:0;
  background:url("../assets/img/pr-cta-bg.png") center center/cover no-repeat;
  pointer-events:none;
}
.cta__inner{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:0 28px;text-align:center}
.cta__title{font-size:52px;font-weight:900;color:var(--navy);letter-spacing:4px;line-height:1.25}
.cta__rule{position:relative;display:block;width:520px;max-width:80%;height:2px;background:#c7d2e3;margin:26px auto 30px}
.cta__rule::after{content:"";position:absolute;left:50%;top:-1px;transform:translateX(-50%);
  width:96px;height:4px;background:#2b5bb5;border-radius:2px}
.cta__lead{font-size:19px;color:var(--text);font-weight:500;line-height:1.7}
.cta__lead--sub{margin-top:12px}

.cta__actions{
  display:flex;align-items:center;justify-content:center;gap:56px;
  margin-top:44px;flex-wrap:wrap;
}
.cta__btn{
  display:inline-flex;align-items:center;gap:16px;
  background:var(--navy);color:#fff;height:82px;padding:0 52px 0 40px;
  font-size:24px;font-weight:700;transition:opacity .2s;
  clip-path:polygon(0 0, calc(100% - 26px) 0, 100% 50%, calc(100% - 26px) 100%, 0 100%);
  box-shadow:0 16px 32px rgba(12,35,80,.24);
}
.cta__btn svg{width:28px;height:28px;fill:#fff;flex-shrink:0}
.cta__btn .arr{font-style:normal;font-size:26px;margin-left:4px}
.cta__btn:hover{opacity:.92}
.cta__tel{display:flex;align-items:center;gap:18px}
.cta__tel-ic{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.cta__tel-ic img{width:100%;height:100%;object-fit:contain}
.cta__tel-txt{display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.cta__tel-num{font-size:46px;font-weight:900;color:var(--navy);letter-spacing:1px;line-height:1}
.cta__tel-time{font-size:16px;color:var(--muted)}

.cta__cards{
  display:flex;justify-content:center;gap:26px;margin-top:46px;list-style:none;flex-wrap:wrap;
}
.cta__card{
  display:flex;align-items:center;gap:20px;
  background:#fff;border-radius:16px;padding:24px 40px;
  box-shadow:0 12px 30px rgba(12,35,80,.10);min-width:300px;
}
.cta__card-ic{width:60px;height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.cta__card-ic img{width:100%;height:100%;object-fit:contain}
.cta__card-txt{display:flex;flex-direction:column;align-items:flex-start}
.cta__card-txt b{font-size:24px;font-weight:800;color:var(--navy)}
.cta__card-txt .u{display:block;width:40px;height:3px;background:#2b5bb5;border-radius:2px;margin-top:12px}

@media (max-width:1100px){
  .cta__tel-num{font-size:40px}
  .cta__card{padding:22px 30px;min-width:0;flex:1 1 260px}
}
@media (max-width:900px){
  .cta{padding:62px 0 60px}
  .cta__title{font-size:34px;letter-spacing:2px}
  .cta__lead{font-size:16px}
  .cta__actions{gap:26px}
  .cta__btn{height:70px;font-size:20px;padding:0 44px 0 32px}
  .cta__tel-num{font-size:36px}
  .cta__cards{gap:16px}
  .cta__card{flex:1 1 100%;max-width:420px}
}
@media (max-width:768px){
  .cta__title{font-size:27px}
  .cta__lead{font-size:15px}
  .cta__lead br{display:none}
  .cta__btn{width:100%;max-width:380px;justify-content:center;height:64px;font-size:17px;gap:12px;
    white-space:nowrap;padding:0 40px 0 28px;
    clip-path:polygon(0 0, calc(100% - 20px) 0, 100% 50%, calc(100% - 20px) 100%, 0 100%)}
  .cta__btn svg{width:24px;height:24px}
  .cta__btn .arr{margin-left:0}
  .cta__tel-num{font-size:32px}
  .cta__tel-time{font-size:14px}
}

/* ===== responsive ===== */
@media (max-width:900px){
  .cmp{padding:60px 0 58px}
  .cmp__title{font-size:38px;letter-spacing:5px}
  .cmp__lead{font-size:15px}
  .cmp__grid{grid-template-columns:0.9fr 1.4fr 1fr}
  .cmp__grid>div{padding:15px 10px;font-size:14px}
  .cmp__grid .head{font-size:15px;padding:16px 10px}
  .c3{font-size:16px}
  .cmp__hl{top:-10px;bottom:-8px}
  .cmp__note{font-size:14px;text-align:left}
}
@media (max-width:560px){
  .cmp__grid>div{padding:12px 7px;font-size:12.5px;line-height:1.35}
  .cmp__grid .head{font-size:13px;padding:13px 7px}
  .c3{font-size:14px}
  .cmp__title{font-size:31px}
}

@media (max-width:1100px){
  .phero__title{font-size:58px}
  .phero__card{width:330px;padding:30px 34px 26px}
  .phero__card-price{font-size:44px}
  .phero__card-price b{font-size:30px}
}
@media (max-width:980px){
  .phero__visual{width:100%;height:420px;position:relative}
  .phero__visual>img{-webkit-mask-image:linear-gradient(180deg,#000 60%,rgba(0,0,0,.15) 100%);
    mask-image:linear-gradient(180deg,#000 60%,rgba(0,0,0,.15) 100%);object-position:center}
  .phero__card{top:auto;bottom:24px;right:20px;width:280px}
  .phero__body{width:100%;max-width:none;padding:36px 0 40px}
  .phero__stats{grid-template-columns:repeat(2,1fr);gap:8px 0;background:none;padding-top:0}
  .phero__stats li:nth-child(3){border-left:none}
  .phero__stats li{border-top:1px solid #eef1f6}
}
@media (max-width:768px){
  .phero__visual{height:300px}
  .phero__card{width:236px;padding:22px 22px 20px;bottom:16px;right:14px}
  .phero__card-cat{font-size:18px;padding-bottom:12px;margin-bottom:14px}
  .phero__card-price{font-size:32px}
  .phero__card-price b{font-size:22px}
  .phero__card-note{font-size:14px;margin-top:12px}
  .phero__title{font-size:44px;letter-spacing:3px}
  .phero__label{font-size:16px}
  .phero__lead{font-size:16px}
  .phero__lead br{display:none}
  .phero__btn{height:64px;font-size:17px;width:100%;justify-content:center;gap:12px;white-space:nowrap}
  .phero__btn .arr{margin-left:0}
  .phero__tel{flex-wrap:wrap;font-size:14px}
}
@media (max-width:480px){
  .phero__visual{height:230px}
  .phero__card{width:210px;padding:20px 16px 18px;bottom:12px;right:10px}
  .phero__card-cat{font-size:16px;padding-bottom:10px;margin-bottom:12px}
  .phero__card-price{font-size:26px}
  .phero__card-price b{font-size:17px;margin-right:4px}
  .phero__card-note{font-size:13px;margin-top:10px}
  .phero__btn{font-size:16px;padding:0 20px}
  .phero__title{font-size:36px}
  .phero__stats{grid-template-columns:1fr}
  .phero__stats li:nth-child(3){border-left:none}
  .phero__stats li + li{border-left:none}
}

/* ===== Footer (shared with service page) ===== */
.sfooter{background:var(--navy);color:#fff}
.sfooter__inner{
  max-width:var(--maxw);margin:0 auto;padding:70px 28px 46px;
  display:grid;grid-template-columns:1.2fr 1fr;gap:48px;
}
.sfooter__logo{display:flex;align-items:center;gap:16px}
.sfooter__logo img{width:auto;height:104px;object-fit:contain}
.sfooter__name{font-size:23px;font-weight:800;letter-spacing:.5px}
.sfooter__tag{margin-top:22px;font-size:15px;line-height:1.9;color:rgba(255,255,255,.8)}
.sfooter__btn{
  display:inline-flex;align-items:center;gap:12px;margin-top:28px;
  background:#fff;color:var(--navy);height:56px;padding:0 32px;border-radius:8px;
  font-size:17px;font-weight:700;transition:opacity .2s;
}
.sfooter__btn .arr{font-style:normal;font-size:20px}
.sfooter__btn:hover{opacity:.9}
.sfooter__info{list-style:none;display:flex;flex-direction:column;gap:20px;padding-top:8px}
.sfooter__info li{display:flex;align-items:center;gap:16px;font-size:15px;color:rgba(255,255,255,.9)}
.sfooter__info svg{width:24px;height:24px;fill:#fff;flex-shrink:0;opacity:.95}
.sfooter__info a{color:rgba(255,255,255,.9);transition:opacity .2s}
.sfooter__info a:hover{opacity:.7}
.sfooter__bottom{
  border-top:1px solid rgba(255,255,255,.16);
  max-width:var(--maxw);margin:0 auto;padding:26px 28px 40px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
}
.sfooter__nav{display:flex;flex-wrap:wrap;gap:8px 22px}
.sfooter__nav a{font-size:14px;color:rgba(255,255,255,.82);transition:opacity .2s}
.sfooter__nav a:hover{opacity:.6}
.sfooter__copy{font-size:13px;color:rgba(255,255,255,.6)}
@media (max-width:980px){
  .sfooter__inner{grid-template-columns:1fr;gap:34px}
}
@media (max-width:768px){
  .sfooter__inner{padding:52px 22px 36px}
  .sfooter__name{font-size:19px}
  .sfooter__logo img{height:84px}
  .sfooter__bottom{padding:22px 22px 34px;flex-direction:column;align-items:flex-start;gap:16px}
}
@media (max-width:480px){
  .sfooter__info li{font-size:14px;gap:12px}
}
