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

/* top navy strip */
.topbar{background:var(--navy)}
.topbar__inner{max-width:var(--maxw);margin:0 auto;padding:9px 28px;font-size:14px;font-weight:700;color:#fff;letter-spacing:.5px}

/* ===== hero ===== */
.fhero{position:relative;overflow:hidden;background:#fff}
.fhero__bg{
  position:absolute;top:0;right:0;width:56%;height:78%;z-index:0;pointer-events:none;
  background:url("../assets/img/fl-bg.png") right top/cover no-repeat;opacity:.6;
}
.fhero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:26px 28px 0}
.fhero__crumb{font-size:15px;color:var(--muted)}
.fhero__crumb a{color:var(--muted)}
.fhero__crumb a:hover{color:var(--navy)}

.fhero__main{display:grid;grid-template-columns:34% 66%;gap:30px;align-items:center;padding:44px 0 20px;min-height:520px}
.fhero__label{display:block;font-size:20px;font-weight:800;letter-spacing:3px;color:#2b5bb5}
.fhero__title{margin-top:14px;font-size:52px;font-weight:900;color:var(--navy);letter-spacing:2px;line-height:1.22}
.fhero__rule{display:block;width:64px;height:3px;background:#c7d0e0;margin:24px 0}
.fhero__lead{font-size:16px;line-height:1.95;color:var(--text);font-weight:500}
.fhero__btn{
  display:inline-flex;align-items:center;gap:16px;margin-top:32px;
  background:var(--navy);color:#fff;height:70px;padding:0 42px;border-radius:8px;
  font-size:20px;font-weight:700;transition:opacity .2s;box-shadow:0 14px 30px rgba(12,35,80,.22);
}
.fhero__btn .arr{font-style:normal;font-size:20px}
.fhero__btn:hover{opacity:.92}

/* step cards */
.fsteps{
  list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:14px;position:relative;
}
.fsteps::before{
  content:"";position:absolute;top:64px;left:8%;right:8%;height:2px;background:#cdd8ea;z-index:0;
}
.fstep{
  position:relative;z-index:1;background:#fff;border:1px solid #e6ebf3;border-radius:14px;
  padding:26px 12px 24px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  box-shadow:0 14px 32px rgba(12,35,80,.10);
}
.fstep__no{
  width:52px;height:52px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;
}
.fstep__ic{width:56px;height:56px;display:flex;align-items:center;justify-content:center}
.fstep__ic img{width:100%;height:100%;object-fit:contain}
.fstep__t{font-size:16px;font-weight:700;color:var(--navy);line-height:1.5}

/* bottom feature bar */
.fhero__features{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:10px 28px 56px}
.fhero__features-inner{
  background:#fff;border:1px solid #e6ebf3;border-radius:16px;box-shadow:0 12px 30px rgba(12,35,80,.06);
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;padding:26px 20px;
}
.ffeat{display:flex;align-items:center;gap:18px;justify-content:center;padding:4px 20px}
.ffeat__ic{
  width:56px;height:56px;flex-shrink:0;border-radius:50%;background:#e9eef7;
  display:flex;align-items:center;justify-content:center;
}
.ffeat__ic svg{width:28px;height:28px;fill:var(--navy)}
.ffeat__txt{display:flex;flex-direction:column;gap:3px}
.ffeat__txt b{font-size:20px;font-weight:800;color:var(--navy)}
.ffeat__txt span{font-size:14px;color:var(--muted)}
.ffeat__div{width:1px;height:56px;background:#e3e8f0}

/* ===== responsive ===== */
@media (max-width:1100px){
  .fhero__title{font-size:44px}
  .fhero__main{grid-template-columns:32% 68%}
  .fstep__t{font-size:14px}
}
@media (max-width:900px){
  .fhero__main{display:block;min-height:0;padding:32px 0 8px}
  .fhero__bg{width:100%;height:340px}
  .fhero__body{max-width:none;margin-bottom:36px}
  .fhero__title{font-size:40px}
  .fsteps{grid-template-columns:repeat(5,1fr);gap:10px}
  .fsteps::before{top:56px}
  .fstep{padding:20px 6px 18px;gap:12px}
  .fstep__no{width:46px;height:46px;font-size:18px}
  .fstep__ic{width:44px;height:44px}
  .fstep__t{font-size:12px}
}
@media (max-width:768px){
  .fhero__title{font-size:34px}
  .fhero__label{font-size:16px}
  .fhero__lead{font-size:15px}
  .fhero__lead br{display:none}
  .fhero__btn{width:100%;justify-content:center;height:62px;font-size:18px}
  .fsteps{grid-template-columns:repeat(2,1fr);gap:14px}
  .fsteps::before{display:none}
  .fstep__t{font-size:14px}
  .fhero__features-inner{grid-template-columns:1fr;gap:0;padding:6px 20px}
  .ffeat{justify-content:flex-start;padding:16px 0}
  .ffeat__div{width:auto;height:1px}
}
@media (max-width:480px){
  .fsteps{grid-template-columns:1fr;max-width:360px;margin:0 auto}
  .fstep{flex-direction:row;justify-content:flex-start;text-align:left;gap:16px;padding:16px 20px}
  .fstep__t br{display:none}
  .topbar__inner{font-size:12px;padding:8px 20px}
}

/* ===== shared section head ===== */
.sec-head{text-align:center;margin-bottom:44px}
.sec-head__en{display:block;font-size:15px;font-weight:800;letter-spacing:4px;color:#2b5bb5}
.sec-head__ja{margin-top:8px;font-size:34px;font-weight:900;color:var(--navy);letter-spacing:2px}
.sec-head__rule{display:block;width:56px;height:3px;background:#2b5bb5;border-radius:2px;margin:20px auto 0}

/* ===== FLOW (detailed) ===== */
.flow2{background:#f5f8fc;padding:78px 0}
.flow2__inner{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.flowcards{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.flowcard{
  position:relative;background:#fff;border:1px solid #e6ebf3;border-radius:16px;
  padding:36px 18px 28px;text-align:center;
  box-shadow:0 14px 34px rgba(12,35,80,.08);
}
.flowcard+.flowcard::before{
  content:"›";position:absolute;left:-14px;top:50%;transform:translateY(-50%);
  font-size:30px;font-weight:400;color:#9fb0cd;z-index:2;line-height:1;
}
.flowcard__no{
  position:absolute;top:-16px;left:50%;transform:translateX(-50%);
  width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;
  box-shadow:0 6px 16px rgba(12,35,80,.25);
}
.flowcard__ic{width:60px;height:60px;margin:8px auto 16px;display:flex;align-items:center;justify-content:center}
.flowcard__ic img{width:100%;height:100%;object-fit:contain}
.flowcard__t{font-size:17px;font-weight:800;color:var(--navy);line-height:1.45;min-height:50px;display:flex;align-items:center;justify-content:center}
.flowcard__d{margin-top:12px;font-size:13.5px;line-height:1.85;color:var(--muted);text-align:left}

/* ===== FAQ ===== */
.faq{background:#fff;padding:78px 0}
.faq__inner{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:22px 40px;max-width:1040px;margin:0 auto;align-items:start}
.faqitem{border:1px solid #e6ebf3;border-radius:14px;padding:22px 24px;box-shadow:0 8px 22px rgba(12,35,80,.05)}
.faqitem__q{display:flex;align-items:center;gap:14px;cursor:pointer;list-style:none}
.faqitem__q::-webkit-details-marker{display:none}
.faqitem__q:hover .faqitem__qt{color:#2b5bb5}
.faqitem__chev{
  margin-left:auto;font-size:24px;color:#9fb0cd;line-height:1;
  transform:rotate(90deg);transition:transform .25s;
}
.faqitem[open] .faqitem__chev{transform:rotate(-90deg)}
@keyframes faqOpen{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.faqitem[open] .faqitem__a{animation:faqOpen .28s ease}
.faqitem__badge{
  width:34px;height:34px;flex-shrink:0;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;
}
.faqitem__badge--a{background:#e9eef7;color:var(--navy)}
.faqitem__qt{font-size:16px;font-weight:800;color:var(--navy);line-height:1.5}
.faqitem__a{display:flex;align-items:flex-start;gap:14px;margin-top:14px;padding-top:14px;border-top:1px dashed #e3e8f0}
.faqitem__at{font-size:14.5px;line-height:1.75;color:var(--text);padding-top:4px}

/* ===== CTA band ===== */
.fcta{background:linear-gradient(180deg,#f5f8fc 0%,#eaf0f9 100%);padding:70px 0}
.fcta__inner{
  max-width:1040px;margin:0 auto;padding:0 28px;
  display:flex;align-items:center;gap:56px;
}
.fcta__img{flex:0 0 42%;max-width:440px}
.fcta__img img{width:100%;height:auto;display:block;mix-blend-mode:multiply}
.fcta__body{flex:1}
.fcta__t{font-size:32px;font-weight:900;color:var(--navy);line-height:1.35;letter-spacing:1px}
.fcta__d{margin-top:18px;font-size:15px;line-height:1.9;color:var(--text)}
.fcta__btn{
  display:inline-flex;align-items:center;gap:14px;margin-top:28px;
  background:var(--navy);color:#fff;height:64px;padding:0 40px;border-radius:8px;
  font-size:19px;font-weight:700;transition:opacity .2s;box-shadow:0 14px 30px rgba(12,35,80,.22);
}
.fcta__btn .arr{font-style:normal}
.fcta__btn:hover{opacity:.92}

@media (max-width:1100px){
  .flowcard__t{font-size:15px}
  .flowcard__d{font-size:12.5px}
}
@media (max-width:900px){
  .sec-head__ja{font-size:28px}
  .flowcards{grid-template-columns:repeat(2,1fr);gap:32px 16px}
  .flowcard+.flowcard::before{display:none}
  .fcta__inner{flex-direction:column;gap:32px;text-align:center}
  .fcta__img{flex:none;max-width:360px}
  .fcta__t br{display:none}
  .fcta__d br{display:none}
}
@media (max-width:768px){
  .flow2,.faq{padding:56px 0}
  .faq__grid{grid-template-columns:1fr;gap:16px}
  .faqitem__at{padding-top:2px}
  .fcta__btn{width:100%;justify-content:center;height:58px;font-size:17px}
  .fcta__t{font-size:26px}
}
@media (max-width:480px){
  .flowcards{grid-template-columns:1fr;gap:30px;max-width:340px;margin:0 auto}
  .flowcard__t{min-height:0}
  .flowcard__t br{display: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}}
