@charset "utf-8";
/* CSS Document */
.page-mainvisual_column{
text-align:center;
}
.breadcrumb-list-item br{
display:none;
}
.box26_02 p{
margin: 5px 0 0 0!important;
text-indent:0!important;
padding: 0;
}
.pd-2{
padding-top:1%;
padding-bottom:1%;
}
.office_q_ft span{
color:rgba(44,54,98,1.00)!important;
}
.footer{
margin-bottom:0!important;
}
.breadcrumb-list .breadcrumb-list-item:nth-child(2) {
    display: none;
}
h2{
background:none;
margin:0;
padding:0;
border:none;
}
.ft-normal span{
font-weight:normal!important;
font-size:18px!important;
line-height: 1.5em;
}
.h5_style{
border-bottom:1px dotted rgba(44,54,98,1.00);
font-size:24px;
margin-top: 3%;
padding-bottom: 6px;
}
.h6_style{
font-size:24px;
margin-top: 3%;
}
strong{
background:none!important;
}

/* ========== Brand variables ========== */
:root{
  --brand:#2b3663;
  --brand-light:#3f4d8a;
  --brand-bg:#f4f6fb;
  --brand-soft:#e7ecf6;
  --ink:#1f2a44;
  --muted:#566080;
  --line:#d8dde9;
  --accent:#c84a4a;
  --accent-soft:#fdecec;
  --gold:#b88746;
  --gold-soft:#fbf3e6;
  --ok:#2f7d56;
  --ok-soft:#e6f1ea;
  --ng:#c0392b;
  --ng-soft:#fbebe8;
}

/* ========== Lead block ========== */
.lead-block{
  background:linear-gradient(180deg,#f7f8fc 0%,#fff 100%);
  border-left:6px solid var(--brand);
  padding: 22px 22px 18px;
  border-radius: 6px;
  margin: 18px 0 28px;
  box-shadow: 0 1px 0 rgba(43,54,99,0.04);
}
.lead-block p{ margin: 0 0 10px; line-height: 1.85;}
.lead-block p:last-child{margin-bottom:0;}
.lead-block strong{color:var(--brand);}

/* ========== Quote bubbles for victim voices ========== */
.voice-stack{
  margin: 14px 0 6px;
  display:grid;
  gap:10px;
}
.voice-bubble{
  position:relative;
  padding: 12px 16px 12px 46px;
  background:#fff;
  border:1px solid var(--line);
  border-left:4px solid var(--accent);
  border-radius:6px;
  font-size:16px;
  line-height:1.7;
}
.voice-bubble::before{
  content:"”";
  position:absolute;
  left: 14px;
  top: 0;
  font-size: 42px;
  color: var(--accent);
  font-family: Georgia, serif;
  line-height: 1.1;
  font-weight: 700;
}

/* ========== Reason cards (3 structural reasons) ========== */
.reason-stack{margin: 22px 0 8px;}
.reason-block{
  background:#fff;
  border:1px solid var(--line);
  border-left:5px solid var(--brand);
  border-radius:6px;
  padding: 18px 20px;
  margin-bottom: 14px;
}
.reason-block .r-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom: 10px;
}
.reason-block .r-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px; height:32px;
  border-radius:50%;
  background:var(--brand);
  color:#fff;
  font-weight:700;
  font-size:17px;
  flex-shrink:0;
}
.reason-block .r-title{
  font-size: 20px;
  font-weight: 700;
  color: var(--brand);
  line-height:1.4;
}
.reason-block p{
  margin: 0 0 8px;
  line-height:1.85;
  font-size: 16.5px;
}
.reason-block p:last-child{margin-bottom:0;}
.inline-list{
  background: var(--brand-bg);
  padding: 12px 16px 12px 18px;
  border-radius: 4px;
  margin: 10px 0;
  list-style:none;
}
.inline-list li{
  position: relative;
  padding-left: 18px;
  margin: 4px 0 !important;
  text-indent: 0 !important;
  font-size: 16px;
  line-height: 1.7;
}
.inline-list li::before{
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--brand);
  font-weight: 700;
}
.inline-quotes{
  margin: 10px 0;
  padding: 12px 16px;
  background: var(--accent-soft);
  border-radius: 4px;
  font-size: 15.5px;
  line-height: 1.8;
  color: var(--ink);
}
.inline-quotes .q{
  display:inline-block;
  margin: 2px 6px 2px 0;
}

/* ========== Case comparison (NG vs OK) ========== */
.case-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 20px 0;
}
.case-card{
  border-radius:10px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  display:flex;
  flex-direction:column;
}
.case-card .c-head{
  padding: 12px 18px;
  font-size:17px;

  font-weight:700;
  letter-spacing:0.02em;
  display:flex;
  align-items:center;
  gap:8px;
  color:#fff;
}
.case-card.is-ng .c-head{background:var(--ng);}
.case-card.is-ok .c-head{background:var(--ok);}
.case-card .c-head .c-mark{
  font-size:22px;
  line-height:1;
}
.case-card .c-body{
  padding: 16px 18px 18px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.case-card .c-body p{
  margin: 0 0 10px;
  line-height: 1.8;
  font-size: 16px;
}
.case-card .c-body p:last-child{margin-bottom:0;}
.case-card .c-result{
  margin-top: auto;
  padding: 12px 14px;
  border-radius: 6px;
  font-size: 16px;
  line-height: 1.7;
}
.case-card.is-ng .c-result{
  background: var(--ng-soft);
  border-left: 4px solid var(--ng);
}
.case-card.is-ok .c-result{
  background: var(--ok-soft);
  border-left: 4px solid var(--ok);
}
.case-card .c-result strong{
  display:block;
  font-size:14px;
  letter-spacing:0.1em;
  margin-bottom: 4px;
}
.case-card.is-ng .c-result strong{color:var(--ng);}
.case-card.is-ok .c-result strong{color:var(--ok);}
.case-conclusion{
  margin: 6px 0 0;
  padding: 14px 16px;
  background: linear-gradient(90deg, var(--brand) 0%, var(--brand-light) 100%);
  color:#fff;
  border-radius: 6px;
  font-size: 16.5px;
  line-height: 1.8;
  text-align:center;
}
.case-conclusion strong{color:#fff8d6;}
@media screen and (max-width: 768px) {
  .case-grid{grid-template-columns:1fr;}
}

/* ========== Suppress empty <p> injected by WP auto-formatter ========== */
.check-item p:empty,
.reason-block p:empty,
.case-card p:empty,
.phase-block p:empty,
.md-col p:empty,
.support-box p:empty,
.consult-box p:empty,
.lead-block p:empty,
.outro-block p:empty,
.pdf-list-box p:empty{
  display:none !important;
}

/* ========== Checklist ========== */
.check-stack{margin: 22px 0 8px;}
.check-item{
  display:grid;
  grid-template-columns: 78px 1fr;
  gap: 16px;
  align-items: stretch;
  background:#fff;
  border:1px solid var(--line);
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
  transition: border-color .2s ease;
}
.check-item:hover{border-color: var(--brand);}
.check-item .ck-num{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background: var(--brand-soft);
  color: var(--brand);
  text-align:center;
  padding: 12px 6px;
  font-weight:700;
  letter-spacing:0.04em;
}
.check-item .ck-num .ck-lbl{
  font-size: 12px;
  letter-spacing: 0.18em;
  opacity: 0.8;
}
.check-item .ck-num .ck-no{
  font-size: 28px;
  line-height: 1;
  margin-top: 2px;
}
.check-item .ck-body{
  padding: 14px 18px 16px;
}
.check-item .ck-title{
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 19px;
  font-weight: 700;
  color: var(--brand);
  line-height: 1.45;
  margin-bottom: 8px;
}
.check-item .ck-title::before{
  content: "✓";
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 22px;
  height: 22px;
  background: var(--ok);
  color:#fff;
  border-radius:4px;
  font-size: 15px;
  font-weight: 900;
  margin-top: 2px;
}
.check-item .ck-body p{
  margin: 0 0 6px;
  line-height: 1.8;
  font-size: 16px;
}
.check-item .ck-body p:last-child{margin-bottom:0;}
.check-item .ck-body strong{color: var(--brand);}
.sub-points{
  background: var(--brand-bg);
  padding: 10px 14px;
  border-radius: 4px;
  margin: 8px 0 6px;
  list-style: none;
}
.sub-points li{
  position: relative;
  padding-left: 16px;
  margin: 3px 0 !important;
  text-indent: 0 !important;
  font-size: 15.5px;
  line-height: 1.7;
}
.sub-points li::before{
  content: "・";
  position: absolute;
  left: 0;
  color: var(--brand);
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .check-item{grid-template-columns: 62px 1fr;}
  .check-item .ck-num .ck-no{font-size: 24px;}
  .check-item .ck-title{font-size: 17px;}
}

/* ========== Phase comparison table ========== */
.phase-stack{margin: 20px 0 8px;}
.phase-block{
  background:#fff;
  border:1px solid var(--line);
  border-radius:8px;
  margin-bottom: 14px;
  overflow:hidden;
}
.phase-block .ph-head{
  background: var(--brand);
  color:#fff;
  padding: 10px 18px;
  font-size:17px;
  font-weight:700;
  letter-spacing:0.04em;
  display:flex;
  align-items:center;
  gap:10px;
}
.phase-block .ph-step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:24px; height:24px;
  border-radius:50%;
  background:rgba(255,255,255,0.2);
  font-size:14px;
  flex-shrink:0;
}
.phase-block .ph-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
}
.phase-block .ph-cell{
  padding: 14px 18px;
  font-size:16px;
  line-height:1.75;
}
.phase-block .ph-cell.ph-normal{
  background:#fafbfd;
  border-right: 1px solid var(--line);
  color: var(--muted);
}
.phase-block .ph-cell.ph-pro{
  background:#fff;
  color: var(--ink);
}
.phase-block .ph-tag{
  display:inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.1em;
  padding: 2px 8px;
  border-radius: 3px;
  margin-bottom: 6px;
}
.phase-block .ph-cell.ph-normal .ph-tag{
  background: #e3e6ee;
  color: var(--muted);
}
.phase-block .ph-cell.ph-pro .ph-tag{
  background: var(--brand);
  color: #fff;
}
.phase-summary{
  margin: 10px 0 0;
  padding: 14px 16px;
  background: var(--gold-soft);
  border-left: 4px solid var(--gold);
  border-radius: 4px;
  font-size: 16.5px;
  line-height: 1.85;
  text-align:center;
  font-weight: 700;
  color:#8c6534;
}
@media screen and (max-width: 768px) {
  .phase-block .ph-grid{grid-template-columns:1fr;}
  .phase-block .ph-cell.ph-normal{border-right:none; border-bottom:1px solid var(--line);}
}

/* ========== Merit / Demerit ========== */
.md-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin: 18px 0 8px;
}
.md-col{
  background:#fff;
  border-radius:10px;
  overflow:hidden;
  border:1px solid var(--line);
}
.md-col .md-head{
  padding: 12px 18px;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.04em;
  display:flex;
  align-items:center;
  gap: 8px;
}
.md-col.is-merit .md-head{background:var(--ok);}
.md-col.is-demerit .md-head{background:var(--gold);}
.md-col .md-head .md-icon{font-size: 19px;}
.md-col .md-body{padding: 12px 18px 16px;}
.md-item{
  padding: 12px 0;
  border-bottom: 1px dotted #e5e8f0;
}
.md-item:last-child{border-bottom:none;}
.md-item .md-num{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 14px;
  font-weight: 700;
  margin-right: 6px;
  vertical-align: middle;
}
.md-col.is-merit .md-num{background: var(--ok-soft); color: var(--ok);}
.md-col.is-demerit .md-num{background: var(--gold-soft); color: #8c6534;}
.md-item .md-title{
  font-weight: 700;
  font-size: 16.5px;
  display:inline;
}
.md-col.is-merit .md-item .md-title{color: var(--ok);}
.md-col.is-demerit .md-item .md-title{color: #8c6534;}
.md-item .md-desc{
  margin: 4px 0 0;
  font-size: 15.5px;
  line-height: 1.75;
  color: var(--ink);
}
@media screen and (max-width: 768px) {
  .md-grid{grid-template-columns:1fr;}
}

/* ========== Our support box ========== */
.support-box{
  margin: 18px 0 8px;
  background: linear-gradient(180deg,#fff 0%, #f7f8fc 100%);
  border: 2px solid var(--brand);
  border-radius: 10px;
  overflow: hidden;
}
.support-box .sp-head{
  background: var(--brand);
  color: #fff;
  padding: 12px 22px;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  gap: 10px;
}
.support-box .sp-head::before{
  content: "◆";
  color: var(--gold);
}
.support-box .sp-body{padding: 18px 22px 20px;}
.support-box .sp-body p{margin: 0 0 10px; line-height: 1.85;}
.team-row{
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--brand-soft);
  align-items: center;
}
.team-row:last-of-type{border-bottom: none;}
.team-row .t-label{
  background: var(--brand);
  color: #fff;
  text-align: center;
  padding: 6px 8px;
  border-radius: 4px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.team-row .t-desc{
  font-size: 16px;
  line-height: 1.75;
}
.support-list-title{
  margin: 16px 0 8px !important;
  font-size: 17px;
  font-weight: 700;
  color: var(--brand);
  letter-spacing: 0.04em;
  padding-left: 12px;
  border-left: 4px solid var(--gold);
}
.support-list{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 18px;
  list-style: none;
  padding: 8px 0;
  margin: 0;
}
.support-list li{
  position: relative;
  padding-left: 22px;
  font-size: 15.5px;
  line-height: 1.75;
  margin: 0 !important;
  text-indent: 0 !important;
}
.support-list li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 1px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--brand);
  color: #fff;
  text-align: center;
  font-size: 12px;
  line-height: 16px;
  font-weight: 700;
}
.support-motto{
  margin: 14px 0 0;
  padding: 14px 18px;
  background: var(--brand-soft);
  border-radius: 6px;
  text-align: center;
  font-size: 17px;
  font-weight: 700;
  color: var(--brand);
  line-height: 1.7;
  letter-spacing: 0.04em;
}
@media screen and (max-width: 768px) {
  .team-row{grid-template-columns: 100px 1fr;}
  .support-list{grid-template-columns: 1fr;}
}

/* ========== Summary ========== */
.summary-block{
  margin: 26px 0 18px;
  padding: 24px 26px;
  background: linear-gradient(180deg, var(--brand) 0%, var(--brand-light) 100%);
  color:#fff;
  border-radius: 10px;
}
.summary-block h3{
  color:#fff !important;
  margin: 0 0 14px !important;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.25);
  font-size:24px;
  background: none !important;
}
.summary-list{
  list-style: none;
  padding: 0;
  margin: 0;
}
.summary-list li{
  position: relative;
  padding: 10px 0 10px 44px;
  border-bottom: 1px solid rgba(255,255,255,0.15);
  line-height: 1.8;
  font-size: 16.5px;
  margin: 0 !important;
  text-indent: 0 !important;
}
.summary-list li:last-child{border-bottom: none;}
.summary-list li::before{
  content: attr(data-num);
  position: absolute;
  left: 0; top: 12px;
  width: 30px; height: 30px;
  background:#fff;
  color: var(--brand);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 15px;
}

/* ========== Outro block ========== */
.outro-block{
  margin: 22px 0 8px;
  padding: 18px 22px;
  background: var(--brand-bg);
  border-radius: 6px;
  line-height: 1.85;
}
.outro-block p{margin: 0 0 10px;}
.outro-block p:last-child{margin-bottom:0;}
.outro-block strong{color: var(--brand);}

/* ========== Consultation CTA ========== */
.consult-box{
  margin: 30px 0 14px !important;
  background: #fff !important;
  background-image: none !important;
  border: 2px solid var(--brand) !important;
  border-radius: 14px !important;
  padding: 28px 30px 24px !important;
  color: var(--ink) !important;
  position: relative !important;
  overflow: hidden !important;
}
.consult-box::before{
  content: "" !important;
  position: absolute !important;
  top: -30px !important;
  right: -30px !important;
  width: 180px !important;
  height: 180px !important;
  background: var(--gold-soft) !important;
  border-radius: 50% !important;
  z-index: 0 !important;
}
.consult-box .ct-head{
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin-bottom: 14px !important;
  padding-bottom: 14px !important;
  border-bottom: 1px solid var(--brand-soft) !important;
  position: relative !important;
  z-index: 1 !important;
}
.consult-box .ct-head .ct-icon{
  font-size: 28px !important;
  color: var(--brand) !important;
}
.consult-box .ct-head .ct-title{
  font-size: 24px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  line-height: 1.4 !important;
  color: var(--brand) !important;
}
.consult-box .ct-tag{
  display: inline-block !important;
  background: var(--accent) !important;
  color: #fff !important;
  font-size: 13px !important;
  padding: 3px 12px !important;
  border-radius: 3px !important;
  letter-spacing: 0.1em !important;
  margin-right: 8px !important;
  vertical-align: middle !important;
}
.consult-box p{
  margin: 0 0 14px !important;
  line-height: 1.85 !important;
  font-size: 16.5px !important;
  color: var(--ink) !important;
  position: relative !important;
  z-index: 1 !important;
}
.consult-box p strong.ct-highlight{
  color: var(--accent) !important;
  background: linear-gradient(transparent 60%, #fff0c8 60%) !important;
  padding: 0 2px !important;
}
.consult-box .ct-bring-title{
  margin: 14px 0 8px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--brand) !important;
  letter-spacing: 0.04em !important;
  padding-left: 12px !important;
  border-left: 4px solid var(--gold) !important;
  position: relative !important;
  z-index: 1 !important;
}
.consult-box .ct-bring{
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px 18px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 14px !important;
  position: relative !important;
  z-index: 1 !important;
}
.consult-box .ct-bring li{
  position: relative !important;
  padding-left: 18px !important;
  font-size: 15.5px !important;
  line-height: 1.75 !important;
  margin: 0 !important;
  text-indent: 0 !important;
  color: var(--ink) !important;
}
.consult-box .ct-bring li::before{
  content: "▸" !important;
  position: absolute !important;
  left: 0 !important;
  color: var(--brand) !important;
  font-weight: 700 !important;
}
.consult-box .ct-foot{
  margin-top: 14px !important;
  padding: 12px 16px !important;
  background: var(--brand-bg) !important;
  border-radius: 6px !important;
  font-size: 15.5px !important;
  color: var(--ink) !important;
  position: relative !important;
  z-index: 1 !important;
}
@media screen and (max-width: 768px) {
  .consult-box{padding: 22px 20px !important;}
  .consult-box .ct-head .ct-title{font-size: 19px !important;}
  .consult-box .ct-bring{grid-template-columns: 1fr !important;}
}

/* ========== PDF list ========== */
.pdf-list-box{
  margin: 18px 0 8px;
  padding: 20px 22px;
  background: var(--gold-soft);
  border: 2px dashed var(--gold);
  border-radius: 10px;
}
.pdf-list-box h4{
  margin: 0 0 10px !important;
  color: #8c6534;
  font-size: 19px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.pdf-list-box h4 .pdf-list-icon{font-size: 24px;}
.pdf-list{
  list-style: none;
  padding: 0;
  margin: 0;
}
.pdf-list li{
  position: relative;
  padding: 6px 0 6px 28px;
  font-size: 16px;
  line-height: 1.7;
  margin: 0 !important;
  text-indent: 0 !important;
}
.pdf-list li::before{
  content: "📄";
  position: absolute;
  left: 0;
  top: 6px;
}
.pdf-list li strong{color: #8c6534;}
.pdf-list li .pdf-sub{
  display: block;
  font-size: 14px;
  color: var(--muted);
  margin-top: 2px;
}

/* ========== Disclaimer ========== */
.disclaimer-final{
  margin-top: 26px;
  padding: 14px 16px;
  background: #f7f7f9;
  border: 1px solid #e2e4ec;
  border-radius: 4px;
  font-size: 14.5px;
  line-height: 1.7;
  color: #66708a;
}

/* ========== Misc ========== */
h3{
  color: var(--brand);
  margin: 36px 0 14px !important;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--brand);
  font-size: 24px;
  line-height:1.45;
}
h4{
  color: var(--brand);
  font-size: 22px;
  margin: 24px 0 10px !important;
}
h4.subhead{
  padding-left: 12px;
  border-left: 4px solid var(--brand);
}

