@charset "UTF-8";
/* =========================================================
   特殊清掃ランディング — 不用品回収グッドサービス
   メインカラー: #6CB3FF
   コンセプト: 親しみやすさ・やわらかさ・安心感
   ========================================================= */

/* ===== TOKENS ===== */
:root{
  --main:#6CB3FF;
  --main-deep:#3A95EC;
  --main-darker:#1F6EBD;
  --main-soft:#E8F3FF;
  --main-pale:#F4F9FF;

  --sub-navy:#2F4F7D;
  --sub-navy-soft:#5A7AA6;

  --warm:#FFE7B8;
  --warm-deep:#FFB452;
  --warm-pale:#FFF8EC;
  --peach:#FFD9C9;
  --mint:#CDEEDD;
  --pink:#FFDFEB;

  --text:#324158;
  --text-sub:#5A6F8C;
  --text-mute:#9AABC0;

  --bg:#FFFFFF;
  --bg-soft:#F4F9FE;
  --bg-warm:#FFFBF3;
  --bg-blue:#EAF4FF;

  --border:#DCE7F5;
  --border-soft:#ECF3FB;
  --border-warm:#FFE7C4;

  --line:#06C755;
  --line-deep:#04A848;
  --tel:#FF8442;
  --tel-deep:#E76A23;
  --warn:#E08AAB;

  --shadow-xs:0 2px 8px rgba(108,179,255,.10);
  --shadow-sm:0 8px 20px rgba(108,179,255,.14);
  --shadow-md:0 14px 36px rgba(108,179,255,.18);
  --shadow-soft:0 18px 44px rgba(47,79,125,.10);
  --shadow-warm:0 10px 28px rgba(255,180,82,.20);

  --radius-xs:8px;
  --radius-sm:14px;
  --radius:20px;
  --radius-lg:28px;
  --radius-xl:36px;
  --radius-pill:999px;

  --max:1180px;
  --wide:1320px;
  --narrow:920px;

  --font:"Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  --font-alt:"Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-bounce:cubic-bezier(.34,1.5,.64,1);
  --t-fast:.18s var(--ease);
  --t-med:.32s var(--ease);

  --header-h-pc:92px;
  --header-h-sp:64px;
  --nav-h-pc:42px;
  --nav-h-sp:40px;
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font);
  font-size:16px;
  line-height:1.9;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  font-feature-settings:"palt";
  letter-spacing:.02em;
}
img,svg{max-width:100%;height:auto;vertical-align:middle}
a{color:var(--main-deep);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--main-darker)}
button{font:inherit}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,h4,h5{margin:0;line-height:1.5}
p{margin:0;font-weight:500}
table{border-collapse:collapse;width:100%}
strong{font-weight:800}

/* utilities */
.wrap{width:min(100% - 2rem, var(--max));margin-inline:auto}
.wrap.narrow{width:min(100% - 2rem, var(--narrow))}
.only-sp{display:inline}
@media(min-width:768px){.only-sp{display:none}}
.only-pc{display:none}
@media(min-width:768px){.only-pc{display:inline}}
.visually-hidden{
  position:absolute!important;
  width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
[id]{scroll-margin-top:calc(var(--header-h-sp) + var(--nav-h-sp) + 12px)}
@media(max-width:899px){
  [id]{scroll-margin-top:150px}
}
@media(min-width:1024px){
  [id]{scroll-margin-top:calc(var(--header-h-pc) + var(--nav-h-pc) + 12px)}
}

.skip-link{
  position:absolute;left:-9999px;z-index:9999;
  padding:.75rem 1.25rem;background:var(--main-deep);color:#fff;font-weight:700;
  border-radius:0 0 12px 0;
}
.skip-link:focus{left:0;top:0}

a:focus-visible,button:focus-visible,summary:focus-visible{
  outline:3px solid var(--main);outline-offset:3px;border-radius:6px;
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header-wrap{
  position:sticky;top:0;z-index:50;
}
.site-header{
  position:relative;
  background:#fff;
  border-bottom:1px solid var(--border-soft);
  box-shadow:0 2px 12px rgba(108,179,255,.06);
}
.site-header__inner{
  width:min(100% - 1.5rem, var(--wide));
  margin-inline:auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:1rem;
  min-height:0;
  padding:.4rem 0;
}
.site-header__contact{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:.35rem;
}
.site-header__brand{
  display:flex;align-items:center;gap:.75rem;
  color:var(--sub-navy);
  margin-right:auto;
}
.site-header__brand:hover{color:var(--main-deep)}
.site-header__brand-mark{
  display:inline-grid;place-items:center;
  width:44px;height:44px;flex-shrink:0;
}
.site-header__brand-mark svg{
  filter:drop-shadow(0 4px 8px rgba(108,179,255,.3));
}
.site-header__brand-name{display:flex;flex-direction:column;line-height:1.2}
.site-header__brand-sub{
  font-size:.82rem;font-weight:700;color:var(--main-deep);
  letter-spacing:.05em;
}
.site-header__brand-main{
  display:block;
  height:28px;
  width:auto;
  max-width:none;
  align-self:flex-start;
}

.site-header__actions{display:flex;align-items:stretch;gap:.5rem}
.hd-btn{
  display:flex;align-items:center;gap:.4rem;
  padding:.3rem .8rem;
  border-radius:var(--radius-sm);
  font-weight:800;text-align:center;line-height:1.25;
  border:2px solid transparent;
  transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
}
.hd-btn__line{font-size:1rem;color:#fff;letter-spacing:.04em;white-space:nowrap}
.hd-btn__ico{
  display:inline-grid;place-items:center;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.22);color:#fff;
}
.hd-btn--tel{
  background:linear-gradient(135deg,var(--tel) 0%,var(--tel-deep) 100%);color:#fff;
  border-color:var(--tel-deep);
  flex-direction:row;align-items:center;gap:.6rem;
  padding:.3rem .85rem;
  transition:transform var(--t-fast),box-shadow var(--t-fast),filter var(--t-fast);
}
.hd-btn--tel:hover{filter:brightness(.92);transform:translateY(-2px)}
.hd-btn--tel .hd-btn__ico{
  background:rgba(255,255,255,.22);color:#fff;
  flex-shrink:0;
}
.hd-btn__tel-body{
  display:flex;flex-direction:column;align-items:flex-start;
  gap:.1rem;
}
.hd-btn--tel .hd-btn__num{
  font-size:1.75rem;font-weight:900;color:#fff;
  letter-spacing:.02em;line-height:1;
  font-family:var(--font-alt);
  white-space:nowrap;
}
.hd-btn--tel .hd-btn__hours{
  font-size:.78rem;color:rgba(255,255,255,.95);font-weight:600;letter-spacing:.02em;
  line-height:1.35;text-align:left;white-space:nowrap;
}
.hd-btn--tel .hd-btn__hours small{
  font-size:.95em;font-weight:500;
  color:rgba(255,255,255,.85);
  letter-spacing:.02em;
}
.hd-btn--line{background:var(--line);color:#fff;border-color:var(--line);padding:.4rem 1.1rem}
.hd-btn--line:hover{background:var(--line-deep);color:#fff;transform:translateY(-2px)}
.hd-btn--mail{background:var(--main-deep);color:#fff;border-color:var(--main-deep)}
.hd-btn--mail:hover{background:var(--main-darker);color:#fff;transform:translateY(-2px)}
.hd-btn--form{background:var(--sub-navy);color:#fff;border-color:var(--sub-navy);padding:.4rem 1.1rem}
.hd-btn--form:hover{background:#1F3556;color:#fff;transform:translateY(-2px)}
.hd-btn:hover{box-shadow:var(--shadow-sm)}

/* --- Tablet PC: 900-1199px --- */
@media(min-width:900px) and (max-width:1199px){
  .site-header__inner{gap:.65rem;padding:.3rem 0}
  .site-header__brand-sub{font-size:.85rem}
  .site-header__brand-main{height:24px}
  .site-header__brand-mark{width:38px;height:38px}
  .site-header__brand-mark svg{width:38px;height:38px}
  .hd-btn{padding:.3rem .6rem;gap:.35rem}
  .hd-btn--tel{padding:.28rem .7rem;gap:.45rem}
  .hd-btn--tel .hd-btn__num{font-size:1.4rem}
  .hd-btn--tel .hd-btn__hours{font-size:.72rem;line-height:1.3}
  .hd-btn__line{font-size:.9rem}
  .hd-btn--line,
  .hd-btn--form{padding:.35rem .85rem}
  .hd-btn__ico{width:28px;height:28px}
  .hd-btn--line .hd-btn__ico img,
  .hd-btn--form .hd-btn__ico svg{width:20px;height:20px}
}

/* --- Header SP: <=899px --- */
@media(max-width:899px){
  .site-header__inner{
    min-height:var(--header-h-sp);
    gap:.5rem;
  }
  .site-header__brand{margin-right:0;gap:.5rem}
  .site-header__brand-mark{width:36px;height:36px}
  .site-header__brand-mark svg{width:36px;height:36px}
  .site-header__brand-sub{font-size:.9rem}
  .site-header__brand-main{height:22px}
  .site-header__contact{flex-basis:100%;gap:.15rem}
  .site-header__actions{
    display:flex;
    justify-content:space-between;
    padding-bottom:.4rem;
    gap:.4rem;
  }
  .site-header__actions .hd-btn{flex:1;padding:.4rem .3rem;min-width:0}
  .hd-btn--tel{flex-direction:row;gap:.4rem;padding:.4rem .4rem}
  .hd-btn--tel .hd-btn__num{font-size:1.15rem}
  .hd-btn--tel .hd-btn__hours{font-size:.6rem;line-height:1.25}
  .hd-btn--line,
  .hd-btn--form{padding:.4rem .5rem}
  .hd-btn__line{font-size:.95rem;white-space:normal;line-height:1.2}
  .hd-btn__ico{width:26px;height:26px}
  .hd-btn--line .hd-btn__ico img,
  .hd-btn--form .hd-btn__ico svg{width:18px;height:18px}
}

/* --- Header narrow mobile: <=480px --- */
@media(max-width:480px){
  .site-header__inner{padding:.3rem 0;gap:.35rem}
  .site-header__brand-mark{width:32px;height:32px}
  .site-header__brand-mark svg{width:32px;height:32px}
  .site-header__brand-sub{font-size:.78rem;letter-spacing:.02em}
  .site-header__brand-main{height:18px}
  .site-header__actions{gap:.3rem}
  .site-header__actions .hd-btn{padding:.35rem .2rem}
  .hd-btn--tel{gap:.25rem;padding:.4rem .2rem}
  .hd-btn--tel .hd-btn__num{font-size:.76rem;letter-spacing:0}
  .hd-btn--tel .hd-btn__hours{display:none}
  .hd-btn__line{font-size:.78rem;letter-spacing:0}
  .hd-btn__ico{width:22px;height:22px}
  .hd-btn--tel .hd-btn__ico{width:20px;height:20px}
  .hd-btn--tel .hd-btn__ico svg{width:13px;height:13px}
  .hd-btn--line .hd-btn__ico img,
  .hd-btn--form .hd-btn__ico svg{width:16px;height:16px}
}

/* --- Header ultra-narrow: <=360px --- */
@media(max-width:360px){
  .site-header__brand-sub{display:none}
  .hd-btn--tel .hd-btn__num{font-size:.76rem}
  .hd-btn--tel .hd-btn__hours{display:none}
  .hd-btn__line{font-size:.72rem}
}

/* =========================================================
   PAGE NAV
   ========================================================= */
.page-nav{
  position:relative;
  z-index:40;
  background:linear-gradient(180deg,#FBFDFF 0%,#F0F7FF 100%);
  border-bottom:2px solid var(--main);
}
.page-nav__inner{
  width:min(100% - 1rem, var(--wide));
  margin-inline:auto;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:.25rem;
  scrollbar-width:none;
  min-height:var(--nav-h-sp);
  align-items:center;
  padding-block:.4rem;
}
@media(min-width:900px){
  .page-nav__inner{
    min-height:var(--nav-h-pc);
    justify-content:center;
    gap:.25rem;
    flex-wrap:nowrap;
    padding-block:0;
  }
}
.page-nav__inner::-webkit-scrollbar{display:none}
.page-nav__inner a{
  display:inline-flex;align-items:center;
  padding:.4rem 1.1rem;margin:0 .1rem;
  color:var(--sub-navy);font-weight:800;font-size:1rem;
  border-radius:999px;white-space:nowrap;
  letter-spacing:.02em;
  transition:background var(--t-fast),color var(--t-fast);
}
.page-nav__inner a:hover{
  background:var(--main);color:#fff;
}

/* hamburger toggle (mobile only) */
.nav-toggle{display:none}
@media(max-width:899px){
  .page-nav{position:relative}
  .site-header{position:relative}
  .nav-toggle{
    display:flex;align-items:center;justify-content:center;
    position:absolute;top:4px;right:10px;z-index:60;
    width:42px;height:32px;padding:0;
    background:#fff;border:1.5px solid var(--main);border-radius:8px;
    box-shadow:0 2px 6px rgba(47,79,125,.12);
    cursor:pointer;
    color:var(--sub-navy);
  }
  .nav-toggle__bars{
    position:relative;display:inline-block;
    width:22px;height:16px;flex-shrink:0;
  }
  .nav-toggle__bars span{
    position:absolute;left:0;right:0;height:2px;
    background:var(--sub-navy);border-radius:2px;
    transition:transform var(--t-fast),opacity var(--t-fast);
  }
  .nav-toggle__bars span:nth-child(1){top:0}
  .nav-toggle__bars span:nth-child(2){top:7px}
  .nav-toggle__bars span:nth-child(3){top:14px}
  .nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] .nav-toggle__bars span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .page-nav__inner{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    width:auto;margin:0;
    flex-direction:column;align-items:stretch;flex-wrap:nowrap;
    gap:.15rem;
    padding:.5rem;
    background:#F0F7FF;
    border-bottom:2px solid var(--main);
    box-shadow:0 14px 26px rgba(47,79,125,.16);
    max-height:72vh;overflow:auto;
    z-index:50;
  }
  .page-nav__inner.is-open{display:flex}
  .page-nav__inner a{
    width:100%;justify-content:flex-start;
    padding:.7rem 1rem;margin:0;
    font-size:1rem;letter-spacing:.02em;
    border-radius:10px;
  }
}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  padding-bottom:60px;
}
.hero__bg{position:absolute;inset:0;z-index:-1;overflow:hidden}
.hero__bg::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 0% 0%, #DDEDFF 0%, transparent 60%),
    radial-gradient(ellipse at 100% 100%, #FFF1DA 0%, transparent 55%),
    linear-gradient(180deg, var(--bg-blue) 0%, var(--main-soft) 100%);
}
.hero__bg-shape{
  position:absolute;border-radius:50%;filter:blur(40px);opacity:.6;
}
.hero__bg-shape--a{
  width:380px;height:380px;background:rgba(108,179,255,.35);
  top:-100px;right:-50px;
}
.hero__bg-shape--b{
  width:260px;height:260px;background:rgba(255,209,140,.4);
  bottom:60px;left:-80px;
}
.hero__bg-shape--c{
  width:180px;height:180px;background:rgba(205,238,221,.6);
  top:60%;left:40%;
}
.hero__bg-wave{
  position:absolute;left:0;right:0;bottom:-1px;
  width:100%;height:80px;
  z-index:2;
}

.hero__inner{
  width:min(100% - 2rem, var(--wide));
  margin-inline:auto;
  padding:1.75rem 0 3.5rem;
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
}
@media(min-width:980px){
  .hero__inner{
    grid-template-columns:1fr 1fr;
    grid-template-areas:
      "intro intro"
      "visual panel";
    gap:2rem 3rem;
    padding:2.5rem 0 4.5rem;
    align-items:start;
  }
  .hero__intro{grid-area:intro}
  .hero__visual{grid-area:visual;align-self:center}
  .hero__panel{grid-area:panel}
}

/* hero intro (top, full width on desktop) */
.hero__intro{
  text-align:center;
  max-width:980px;
  margin-inline:auto;
}
.hero__intro .hero__chip{margin-left:auto;margin-right:auto}
.hero__intro .hero__lead{margin-left:auto;margin-right:auto;text-align:left}
@media(min-width:980px){
  .hero__intro{text-align:center}
  .hero__intro .hero__lead{text-align:center;max-width:64em}
}

/* hero panel (right side: merits + cta) */
.hero__panel{
  position:relative;
  isolation:isolate;
  padding:clamp(1.25rem,3vw,1.75rem) clamp(1rem,2.5vw,1.5rem);
  border-radius:var(--radius-lg);
  background:#fff;
  box-shadow:0 12px 32px rgba(47,79,125,.10);
  border:1.5px solid rgba(108,179,255,.25);
  overflow:hidden;
}
.hero__panel::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background-image:linear-gradient(135deg,
    rgba(244,249,255,.6) 0%,
    rgba(255,255,255,.95) 60%,
    rgba(255,251,243,.6) 100%);
  border-radius:inherit;
}
.hero__panel::after{
  content:"";
  position:absolute;
  top:8px;right:8px;bottom:8px;left:8px;
  z-index:-1;
  border-radius:calc(var(--radius-lg) - 6px);
  border:1.5px dashed rgba(108,179,255,.35);
  pointer-events:none;
}
.hero__panel .hero__merits{margin-bottom:1.25rem}
.hero__panel .hero__cta{margin-top:.25rem}

.hero__chip{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5rem 1.1rem .5rem 1rem;
  background:#fff;
  border:2px solid var(--main);
  border-radius:999px;
  font-size:1rem;font-weight:800;color:var(--sub-navy);
  letter-spacing:.02em;
  margin-bottom:1.25rem;
  box-shadow:var(--shadow-xs);
}
.hero__chip strong{color:var(--main-deep);font-weight:900;margin:0}
.hero__chip-pin{font-size:.9em;line-height:1}

.hero__title{
  font-weight:900;
  margin-bottom:1.25rem;
  letter-spacing:.02em;
}
.hero__title-row{display:block;margin-bottom:.25rem}
.hero__title-mark{
  display:inline-block;
  font-size:clamp(1.1rem,2.8vw,1.35rem);
  font-weight:800;
  color:var(--sub-navy);
  background:linear-gradient(transparent 65%, var(--warm) 65%);
  padding:0 .3em;
  line-height:1.6;
}
.hero__title-main{
  display:block;
  font-size:clamp(1.7rem,5.6vw,3rem);
  line-height:1.35;
  color:var(--sub-navy);
  margin-top:.4rem;
}
.hero__title-piece{display:inline-block}
.hero__title-piece--em{
  color:var(--main-deep);
  position:relative;
}
.hero__title-piece--em::after{
  content:"";position:absolute;left:0;right:0;bottom:-.1em;
  height:.15em;
  background:linear-gradient(90deg,var(--main) 0%,var(--main-deep) 100%);
  border-radius:999px;
  opacity:.5;
}
.hero__title-row--small{margin-top:.5rem}
.hero__title-sub{
  display:inline-block;
  font-size:clamp(1rem,2.4vw,1.1rem);
  font-weight:700;
  color:var(--text-sub);
  background:#fff;
  padding:.35rem 1.1rem;
  border-radius:999px;
  border:1.5px dashed var(--main);
}

.hero__lead{
  font-size:clamp(1rem,2.2vw,1.05rem);
  line-height:1.95;
  color:var(--text);
  margin-bottom:1.5rem;
  max-width:42em;
}
.hero__lead strong{color:var(--main-deep);font-weight:800;border-bottom:2px dotted var(--main)}

.hero__merits{
  display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;
  margin-bottom:1.75rem;
  padding:1rem .5rem;
  background:#fff;
  border:2px solid var(--main-soft);
  border-radius:var(--radius);
  box-shadow:var(--shadow-xs);
}
.hero__merits li{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:.4rem;
  padding:.3rem .25rem;
}
.hero__merits li + li{
  border-left:1.5px dashed var(--border);
}
.hero__merits-ico{
  display:inline-grid;place-items:center;
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--main-soft) 0%,#fff 100%);
  color:var(--main-deep);
  border:1.5px solid var(--main);
}
.hero__merits-text{
  font-size:1rem;font-weight:900;color:var(--sub-navy);
  line-height:1.4;letter-spacing:.02em;
}
.hero__merits-text small{
  display:block;font-size:1rem;color:var(--text-sub);
  font-weight:700;margin-top:.15rem;
}

/* hero CTA */
.hero__cta-headline{
  text-align:center;
  margin-bottom:.85rem;
}
.hero__cta-bubble{
  display:inline-block;
  font-weight:900;
  font-size:clamp(1.05rem,2.6vw,1.2rem);
  letter-spacing:.04em;
  color:var(--sub-navy);
  background:#fff;
  padding:.55rem 1.5rem;
  border-radius:999px;
  border:2.5px solid var(--main);
  box-shadow:0 4px 0 0 var(--main-soft);
  position:relative;
}
.hero__cta-row{
  display:grid;grid-template-columns:1fr;gap:.65rem;
}
@media(min-width:560px){
  .hero__cta-row{grid-template-columns:repeat(2,1fr)}
  .hero__cta-row .cta-btn--tel{grid-column:1/-1}
}

/* hero visual (3-image collage) */
.hero__visual{
  position:relative;
  aspect-ratio:1/1.02;
  max-width:540px;
  width:100%;
  margin:1rem auto 0;
}
@media(min-width:980px){
  .hero__visual{aspect-ratio:1/1;max-width:580px;margin-top:0}
}
.hero__visual-blob{
  position:absolute;inset:4% 4% 8% 6%;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  border-radius:46% 54% 60% 40% / 50% 44% 56% 50%;
  filter:blur(2px);opacity:.18;z-index:1;
  animation:blobFloat 14s ease-in-out infinite;
}
@keyframes blobFloat{
  0%,100%{border-radius:46% 54% 60% 40% / 50% 44% 56% 50%}
  50%{border-radius:60% 40% 44% 56% / 56% 60% 40% 44%}
}
.hero__visual-dot{
  position:absolute;border-radius:50%;
  z-index:1;
}
.hero__visual-dot--a{
  width:14px;height:14px;background:var(--warm-deep);
  top:4%;right:20%;
  box-shadow:0 4px 12px rgba(255,180,82,.5);
}
.hero__visual-dot--b{
  width:10px;height:10px;background:var(--main-deep);
  top:60%;right:4%;
  box-shadow:0 4px 12px rgba(58,149,236,.5);
}
.hero__visual-dot--c{
  width:18px;height:18px;background:#fff;
  border:3px solid var(--main);
  top:38%;left:0;
}

/* ---- main image (large, top): staff group ---- */
.hero__visual-main{
  position:absolute;
  top:0;left:10%;
  margin:0;
  width:80%;
  aspect-ratio:5/3.2;
  border-radius:var(--radius-xl);
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-soft);
  border:6px solid #fff;
  z-index:2;
  transform:rotate(-1.5deg);
}
.hero__visual-main img{
  width:100%;height:100%;object-fit:cover;
  display:block;
}

/* ---- sub images (bottom): work + greeting ---- */
.hero__visual-sub{
  position:absolute;
  margin:0;
  aspect-ratio:4/3;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-soft);
  border:5px solid #fff;
  z-index:3;
}
.hero__visual-sub img{
  width:100%;height:100%;object-fit:cover;
  display:block;
}
.hero__visual-sub--work{
  bottom:0;right:0;
  width:50%;
  transform:rotate(3deg);
  z-index:4;
}
.hero__visual-sub--greet{
  bottom:6%;left:2%;
  width:44%;
  transform:rotate(-3deg);
  z-index:3;
}

/* ---- image captions ---- */
.hero__visual-caption{
  position:absolute;
  bottom:8px;left:8px;right:8px;
  font-size:1rem;font-weight:800;color:#fff;
  background:linear-gradient(180deg,transparent 0%,rgba(15,37,71,.85) 100%);
  padding:1.1rem .6rem .45rem;margin:0;
  border-radius:0 0 calc(var(--radius-xl) - 12px) calc(var(--radius-xl) - 12px);
  text-align:center;letter-spacing:.03em;
  pointer-events:none;
}
.hero__visual-caption--alt{
  font-size:1rem;
  border-radius:0 0 calc(var(--radius-lg) - 10px) calc(var(--radius-lg) - 10px);
  padding:1rem .4rem .4rem;
}

/* ---- floating badges ---- */
.hero__visual-stat{
  position:absolute;
  top:-2%;left:-4%;
  width:120px;height:120px;
  border-radius:50%;
  background:linear-gradient(135deg,#fff 0%,var(--main-pale) 100%);
  border:4px solid var(--main);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:var(--shadow-md);
  z-index:5;
  transform:rotate(-8deg);
}
.hero__visual-stat-num{
  font-size:2rem;font-weight:900;color:var(--main-deep);
  line-height:1;letter-spacing:.01em;
  font-family:var(--font-alt);
}
.hero__visual-stat-num small{font-size:.55em;font-weight:800;margin-left:.05em}
.hero__visual-stat-label{
  font-size:1rem;font-weight:800;color:var(--sub-navy);
  margin-top:.3rem;letter-spacing:.04em;
}
.hero__visual-tag{
  position:absolute;
  top:46%;right:-4%;
  background:var(--warm-deep);
  color:#fff;
  padding:.6rem 1.1rem .6rem .85rem;
  border-radius:14px 14px 4px 14px;
  font-size:1rem;font-weight:800;
  display:inline-flex;align-items:center;gap:.4rem;
  box-shadow:var(--shadow-warm);
  z-index:5;
  transform:rotate(4deg);
}
.hero__visual-tag-ico{
  font-size:.95em;color:#fff;
  background:rgba(255,255,255,.25);
  width:22px;height:22px;border-radius:50%;
  display:inline-grid;place-items:center;
  line-height:1;
}
.hero__visual-tag-text strong{
  font-size:1.15em;margin:0 .1em;font-weight:900;
}

/* ---- speech bubble ---- */
.hero__visual-bubble{
  position:absolute;
  bottom:-2%;left:36%;
  background:#fff;
  color:var(--sub-navy);
  padding:.6rem .95rem;
  border-radius:14px;
  font-size:1rem;font-weight:800;
  line-height:1.45;
  text-align:center;
  border:2.5px solid var(--main);
  box-shadow:0 6px 18px rgba(47,79,125,.18);
  z-index:5;
  transform:rotate(-3deg);
}
.hero__visual-bubble::after{
  content:"";position:absolute;
  top:-9px;left:50%;transform:translateX(-50%);
  width:0;height:0;
  border:8px solid transparent;
  border-bottom-color:var(--main);
  border-top:0;
}
.hero__visual-bubble::before{
  content:"";position:absolute;
  top:-5px;left:50%;transform:translateX(-50%);
  width:0;height:0;
  border:7px solid transparent;
  border-bottom-color:#fff;
  border-top:0;z-index:1;
}
.hero__visual-bubble-text strong{
  color:var(--main-deep);font-weight:900;
}

@media(max-width:560px){
  .hero__visual{max-width:420px;margin-bottom:7rem}
  .hero__lead{margin-bottom:4rem}
  .hero__visual-stat{width:104px;height:104px;border-width:3px;top:-16%}
  .hero__visual-stat-num{font-size:1.6rem}
  .hero__visual-stat-label{font-size:1rem;margin-top:.25rem}
  .hero__visual-tag{font-size:1rem;padding:.5rem .75rem .5rem .65rem}
  .hero__visual-tag-ico{width:22px;height:22px;font-size:.95em}
  .hero__visual-bubble{font-size:1rem;padding:.55rem .85rem;left:50%;right:auto;bottom:-30%;transform:translateX(-50%) rotate(-3deg)}
  .hero__visual-caption{font-size:1rem;padding:1rem .4rem .4rem}
  .hero__visual-caption--alt{font-size:1rem;padding:.95rem .35rem .35rem}
  .hero__visual-main{border-width:5px}
  .hero__visual-sub{border-width:4px}
}

/* =========================================================
   HERO Responsive Optimizations
   ========================================================= */
/* Tablet PC: 980-1199px (2-col layout, optimize panel & visual) */
@media(min-width:980px) and (max-width:1199px){
  .hero__inner{gap:1.5rem 2rem;padding:2rem 0 3.5rem}
  .hero__visual{max-width:480px}
  .hero__panel{padding:1.25rem 1.1rem}
  .hero__panel .hero__merits{padding:.75rem .35rem;margin-bottom:1rem}
  .hero__panel .hero__merits-ico{width:36px;height:36px}
  .hero__panel .hero__merits-text{font-size:.9rem}
  .hero__panel .hero__merits-text small{font-size:.8rem}
  .hero__panel .hero__cta-bubble{font-size:1rem;padding:.45rem 1.2rem}
  .hero__panel .cta-btn{padding:.7rem .9rem;gap:.5rem}
  .hero__panel .cta-btn__ico{width:36px;height:36px}
  .hero__panel .cta-btn__main{font-size:1.05rem}
  .hero__panel .cta-btn--tel .cta-btn__main{font-size:clamp(1.5rem,3vw,1.9rem)}
  .hero__panel .cta-btn__sub{font-size:.85rem}
}

/* Tablet portrait: 768-979px (single column, larger fonts on intro) */
@media(min-width:768px) and (max-width:979px){
  .hero__inner{padding:2rem 0 3rem;gap:2rem}
  .hero__visual{max-width:520px}
  .hero__intro{text-align:center}
  .hero__intro .hero__lead{text-align:center;margin-inline:auto}
  .hero__panel{max-width:680px;margin-inline:auto}
}

/* Small tablet / large mobile: 481-767px */
@media(max-width:767px){
  .hero{padding-bottom:32px}
  .hero__inner{padding:1.25rem 0 2.5rem;gap:1.25rem}
  .hero__visual{max-width:460px;margin-top:.5rem}
  .hero__panel{padding:1.1rem 1rem}
}

/* Narrow mobile: <=480px */
@media(max-width:480px){
  .hero__inner{padding:1rem 0 2rem;gap:1rem}
  .hero__chip{
    font-size:.82rem;
    padding:.35rem .8rem .35rem .7rem;
    gap:.35rem;
    margin-bottom:.85rem;
  }
  .hero__title{margin-bottom:1rem}
  .hero__title-mark{font-size:.95rem;line-height:1.55}
  .hero__title-main{font-size:1.55rem;line-height:1.4;margin-top:.25rem}
  .hero__title-sub{font-size:.85rem;padding:.3rem .8rem}
  .hero__title-row{margin-bottom:.15rem}
  .hero__title-row--small{margin-top:.35rem}
  .hero__lead{font-size:.92rem;line-height:1.8;margin-bottom:4rem}
  .hero__merits{padding:.7rem .3rem;gap:.25rem;margin-bottom:1.1rem}
  .hero__merits li{gap:.25rem;padding:.2rem .15rem}
  .hero__merits-ico{width:34px;height:34px}
  .hero__merits-ico svg{width:18px;height:18px}
  .hero__merits-text{font-size:.78rem;line-height:1.3}
  .hero__merits-text small{font-size:.72rem;margin-top:.1rem}
  .hero__cta-headline{margin-bottom:.6rem}
  .hero__cta-bubble{font-size:.95rem;padding:.4rem 1rem;border-width:2px}
  .hero__panel{padding:.95rem .75rem;border-radius:var(--radius)}
  .hero__panel::after{top:6px;right:6px;bottom:6px;left:6px}
  .hero__visual{max-width:340px}
}

/* Ultra narrow: <=360px */
@media(max-width:360px){
  .hero__title-main{font-size:1.4rem}
  .hero__title-mark{font-size:.88rem}
  .hero__title-sub{font-size:.78rem;padding:.25rem .7rem}
  .hero__lead{font-size:.88rem}
  .hero__merits{grid-template-columns:repeat(3,1fr);padding:.6rem .25rem}
  .hero__merits-text{font-size:.7rem}
  .hero__merits-text small{font-size:.65rem}
  .hero__visual{max-width:300px}
}

/* =========================================================
   CTA BUTTONS (shared)
   ========================================================= */
.cta-btn{
  display:flex;align-items:center;gap:.7rem;
  padding:.85rem 1.1rem;
  border-radius:var(--radius);
  font-weight:800;color:#fff;
  text-align:left;line-height:1.3;
  box-shadow:0 6px 0 0 rgba(0,0,0,.12),0 10px 24px rgba(0,0,0,.18);
  transition:transform var(--t-fast),box-shadow var(--t-fast);
  position:relative;overflow:hidden;
}
.cta-btn:hover{
  transform:translateY(-3px);
  box-shadow:0 9px 0 0 rgba(0,0,0,.12),0 16px 32px rgba(0,0,0,.22);
  color:#fff;
}
.cta-btn:active{transform:translateY(0)}
.cta-btn--lg{padding:1rem 1.3rem;border-radius:var(--radius-lg)}

.cta-btn__ico{
  display:inline-grid;place-items:center;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.25);
  flex-shrink:0;
}
.cta-btn--lg .cta-btn__ico{width:48px;height:48px}
.cta-btn__body{display:flex;flex-direction:column;gap:.1rem;min-width:0}
.cta-btn__label{
  display:inline-block;align-self:flex-start;
  font-size:1rem;background:rgba(255,255,255,.28);
  padding:.1rem .7rem;border-radius:999px;letter-spacing:.06em;font-weight:800;
}
.cta-btn__main{
  font-size:clamp(1.25rem,2.6vw,1.45rem);
  font-weight:900;letter-spacing:.01em;line-height:1.2;
  font-family:var(--font-alt);
}
.cta-btn--lg .cta-btn__main{font-size:clamp(1.35rem,2.8vw,1.6rem)}
.cta-btn__sub{font-size:1rem;font-weight:700;opacity:.94;letter-spacing:.02em}

.cta-btn--tel{
  background:linear-gradient(135deg,var(--tel) 0%,var(--tel-deep) 100%);
  justify-content:center;
  text-align:center;
}
.cta-btn--tel .cta-btn__body{align-items:center;gap:.2rem}
.cta-btn--tel .cta-btn__label{align-self:center}
.cta-btn--tel .cta-btn__main{
  font-size:clamp(1.85rem,4.6vw,2.4rem);
  letter-spacing:.02em;
}
.cta-btn--lg.cta-btn--tel .cta-btn__main{
  font-size:clamp(2rem,5vw,2.6rem);
}
.cta-btn--tel .cta-btn__sub{font-size:1.05rem}
@media(max-width:600px){
  .cta-btn--lg.cta-btn--tel,
  .hero__cta-row .cta-btn--tel{justify-content:flex-start;text-align:left}
  .cta-btn--lg.cta-btn--tel .cta-btn__body,
  .hero__cta-row .cta-btn--tel .cta-btn__body{align-items:flex-start}
  .cta-btn--lg.cta-btn--tel .cta-btn__sub,
  .hero__cta-row .cta-btn--tel .cta-btn__sub{text-align:left}
}
.cta-btn--line{
  background:linear-gradient(135deg,#08D058 0%,var(--line-deep) 100%);
}
.cta-btn--mail{
  background:linear-gradient(135deg,var(--main-deep) 0%,var(--main-darker) 100%);
}
.cta-btn--form{
  background:linear-gradient(135deg,var(--sub-navy) 0%,#1F3556 100%);
}

.hd-btn--line .hd-btn__ico,
.cta-btn--line .cta-btn__ico,
.fixed-cta__btn--line .fixed-cta__ico{
  background:#fff;
  padding:0;
  overflow:hidden;
  border-radius:225px;
}
.hd-btn--line .hd-btn__ico img,
.cta-btn--line .cta-btn__ico img,
.fixed-cta__btn--line .fixed-cta__ico img{
  display:block;
  width:100%;
  height:100%;
  max-width:100%;
  object-fit:cover;
  border-radius:225px;
}

/* =========================================================
   TRUST BAR
   ========================================================= */
.trust-bar{
  background:#fff;
  position:relative;z-index:2;
  border-bottom:1px solid var(--border-soft);
}
.trust-bar__inner{
  width:min(100% - 1.5rem, 1500px);
  margin-inline:auto;padding:1.6rem 0 1.85rem;
}
.trust-bar__list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
  text-align:center;
}
@media(min-width:680px){
  .trust-bar__list{grid-template-columns:repeat(4,1fr)}
}
.trust-bar__list li{
  display:flex;flex-direction:column;align-items:center;gap:.65rem;
  padding:.9rem .6rem;
}
.trust-bar__ico{
  display:inline-grid;place-items:center;
  width:62px;height:62px;border-radius:50%;
  background:var(--main-soft);
  color:var(--main-deep);
}
.trust-bar__ico svg{width:32px;height:32px}
.trust-bar__name{
  font-size:1.2rem;font-weight:800;color:var(--sub-navy);
  letter-spacing:.01em;line-height:1.5;
}
.trust-bar__name strong{
  font-size:1.9rem;font-weight:900;color:var(--main-deep);
  margin:0 .12em;letter-spacing:.01em;
  font-family:var(--font-alt);
}
@media(max-width:560px){
  .trust-bar__ico{width:54px;height:54px}
  .trust-bar__ico svg{width:28px;height:28px}
  .trust-bar__name{font-size:1.05rem}
  .trust-bar__name strong{font-size:1.55rem}
}

/* =========================================================
   SECTION COMMON
   ========================================================= */
.section{
  padding:clamp(3rem,8vw,5.5rem) 0;
  position:relative;
}
.section--worry{background:var(--bg-warm)}
.section--solution{background:var(--bg);position:relative}
.section--solution::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 100% 0%, var(--main-pale) 0%, transparent 50%),
    radial-gradient(ellipse at 0% 100%, var(--warm-pale) 0%, transparent 45%);
  pointer-events:none;z-index:0;
}
.section--solution > .wrap{position:relative;z-index:1}
.section--why{background:var(--bg-blue)}
.section--price{background:var(--bg)}
.section--flow{background:var(--bg-soft)}
.section--cases{background:var(--bg)}
.section--voice{background:linear-gradient(135deg,var(--main-soft) 0%,#fff 50%,var(--warm-pale) 100%)}
.section--faq{background:var(--bg-soft)}
.section--notice{background:#fff;padding:clamp(2rem,5vw,3.5rem) 0;border-top:1px solid var(--border-soft)}

.sec-head{text-align:left;margin-bottom:2.5rem}
.sec-head--center{text-align:center}
.sec-head__bubble{
  display:inline-block;
  font-size:1rem;font-weight:900;letter-spacing:.06em;
  color:#fff;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  padding:.5rem 1.5rem .55rem;
  border-radius:999px;
  margin-bottom:1rem;
  position:relative;
  box-shadow:var(--shadow-sm);
}
.sec-head__bubble::after{
  content:"";position:absolute;
  left:50%;bottom:-8px;transform:translateX(-50%);
  width:0;height:0;
  border:8px solid transparent;
  border-top-color:var(--main-deep);
  border-bottom:0;
}
.sec-head:not(.sec-head--center) .sec-head__bubble::after{
  left:24px;transform:none;
}
.sec-head__title{
  font-size:clamp(1.75rem,4.6vw,2.5rem);
  font-weight:900;color:var(--sub-navy);
  line-height:1.5;letter-spacing:.03em;
  margin-bottom:1rem;
}
.sec-head__title-accent{
  color:var(--main-deep);
  position:relative;display:inline-block;
}
.sec-head__title-accent::after{
  content:"";position:absolute;left:0;right:0;bottom:-.05em;
  height:.18em;
  background:linear-gradient(90deg,var(--main) 0%,var(--warm-deep) 100%);
  border-radius:2px;opacity:.55;
}
.title-em-img{
  display:inline-block;
  height:4.7em;width:auto;
  vertical-align:middle;
  margin:-.7em .3em -.4em;
  image-rendering:auto;
}
.title-em-img--sm{
  height:3.4em;
  margin:-.45em .25em -.2em;
}
#cases-title .title-em-img{
  height:2.2em;
}
@media(max-width:600px){
  .title-em-img{height:3.7em;margin:-.5em .2em -.25em}
  .title-em-img--sm{height:2.7em;margin:-.3em .15em -.15em}
  #cases-title .title-em-img{height:1.7em}
}
.sec-head__lead{
  font-size:1.05rem;line-height:1.95;
  color:var(--text-sub);max-width:48em;
}
.sec-head--center .sec-head__lead{margin-inline:auto}
@media(max-width:600px){
  .section--worry .sec-head{text-align:center}
  .section--worry .sec-head .sec-head__bubble::after{left:50%;transform:translateX(-50%)}
  .section--worry .sec-head__lead{margin-inline:auto}
}

/* =========================================================
   WORRY
   ========================================================= */
.worry-grid{
  display:grid;
  row-gap:2.75rem;
  column-gap:1rem;
  grid-template-columns:repeat(1,1fr);
}
@media(min-width:560px){.worry-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.worry-grid{grid-template-columns:repeat(3,1fr);row-gap:3.25rem}}

.worry-card{
  background:#fff;
  border-radius:var(--radius);
  padding:2.4rem 1.25rem 1.25rem;
  position:relative;
  box-shadow:0 4px 0 var(--main-soft),0 10px 24px rgba(108,179,255,.08);
  border:2px solid #fff;
  display:flex;
  align-items:center;
  gap:1rem;
}
.worry-card__no{
  position:absolute;top:-14px;left:18px;
  background:linear-gradient(135deg,var(--warm-deep) 0%,#FF9E2E 100%);
  color:#fff;font-weight:900;font-size:1rem;
  padding:.35rem 1rem;border-radius:999px;
  letter-spacing:.05em;box-shadow:var(--shadow-warm);
}
.worry-card__ico{
  width:64px;height:64px;border-radius:50%;
  background:var(--main-soft);
  display:grid;place-items:center;
  color:var(--main-deep);
  flex-shrink:0;
}
.worry-card__text{
  font-size:1.05rem;font-weight:800;color:var(--sub-navy);
  line-height:1.65;
  flex:1;
  min-width:0;
}
.worry-card__text strong{color:var(--main-deep);font-weight:900;border-bottom:2px dotted var(--main)}

.worry-card--cta{
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  color:#fff;text-align:center;border-color:transparent;
  padding:1.75rem 1.25rem;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  box-shadow:0 8px 0 var(--main-darker),0 16px 32px rgba(31,110,189,.3);
}
.worry-card--cta:hover{box-shadow:0 10px 0 var(--main-darker),0 18px 36px rgba(31,110,189,.35)}
.worry-card__cta-lead{font-size:1.05rem;font-weight:800;color:rgba(255,255,255,.95);line-height:1.5}
.worry-card__cta-main{
  font-size:1.6rem;font-weight:900;
  margin:.5rem 0 .85rem;color:#fff;letter-spacing:.04em;
  line-height:1.4;
}
.worry-card__cta-btn{
  display:inline-flex;flex-direction:column;align-items:center;
  background:#fff;color:var(--sub-navy);
  padding:.85rem 1.25rem;border-radius:var(--radius-sm);
  font-weight:900;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  width:100%;
}
.worry-card__cta-btn:hover{color:var(--main-deep);background:#fff;transform:translateY(-2px)}
.worry-card__cta-num{font-size:1.55rem;line-height:1.1;letter-spacing:.01em;font-family:var(--font-alt)}
.worry-card__cta-sub{font-size:1rem;color:var(--text-sub);font-weight:700;margin-top:.25rem}

/* =========================================================
   SOLUTION
   ========================================================= */
.solution-brand{
  color:var(--main-deep);
  font-weight:900;
  position:relative;display:inline-block;padding:0 .15em;
}
.solution-brand::after{
  content:"";position:absolute;left:0;right:0;bottom:-.05em;height:.18em;
  background:linear-gradient(90deg,var(--main),var(--main-deep));
  border-radius:2px;opacity:.4;
}

.solution-grid{
  display:grid;gap:1.5rem;
  grid-template-columns:1fr;
}
@media(min-width:768px){.solution-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}

.solution-card{
  background:#fff;color:var(--text);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:0 14px 36px rgba(47,79,125,.10);
  transition:transform var(--t-med),box-shadow var(--t-med);
  display:flex;flex-direction:column;
  border:2px solid #fff;
}
.solution-card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 48px rgba(47,79,125,.18);
  border-color:var(--main-soft);
}
.solution-card__media{
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
  margin:14px 14px 0;
  border-radius:var(--radius);
}
.solution-card__media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease);
}
.solution-card:hover .solution-card__media img{transform:scale(1.06)}
.solution-card__no{
  position:absolute;top:12px;left:12px;
  width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  color:#fff;font-weight:900;font-size:1.45rem;
  display:grid;place-items:center;
  box-shadow:0 6px 16px rgba(47,79,125,.3);
  letter-spacing:.02em;
  font-family:var(--font-alt);
  border:3px solid #fff;
}
.solution-card__body{padding:1.5rem 1.5rem 1.7rem;flex:1;display:flex;flex-direction:column}
.solution-card__catch{
  display:inline-block;
  font-size:1rem;font-weight:800;letter-spacing:.04em;
  color:var(--warm-deep);
  background:var(--warm-pale);
  padding:.35rem 1rem;border-radius:999px;
  margin-bottom:.9rem;align-self:flex-start;
  border:1.5px solid var(--warm);
}
.solution-card__title{
  font-size:1.35rem;font-weight:900;color:var(--sub-navy);
  line-height:1.6;letter-spacing:.02em;
  margin-bottom:.9rem;
}
.solution-card__title strong{color:var(--main-deep)}
.solution-card__text{
  font-size:1rem;line-height:1.95;color:var(--text-sub);
  margin-bottom:1.1rem;flex:1;
}
.solution-card__keys{
  display:flex;flex-wrap:wrap;gap:.45rem;
  padding-top:1.1rem;border-top:2px dashed var(--main-soft);
}
.solution-card__keys li{
  font-size:1rem;font-weight:800;color:var(--sub-navy);
  background:var(--main-pale);
  border:1.5px solid var(--main);
  padding:.35rem .9rem;border-radius:999px;
  position:relative;padding-left:1.9rem;
}
.solution-card__keys li::before{
  content:"✓";position:absolute;left:.6rem;top:50%;
  transform:translateY(-50%);
  color:var(--main-deep);font-weight:900;font-size:1rem;
}

/* =========================================================
   WHY
   ========================================================= */
.why-grid{
  display:grid;gap:1.25rem;
  grid-template-columns:repeat(1,1fr);
}
@media(min-width:560px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.why-grid{grid-template-columns:repeat(4,1fr)}}

.why-card{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:2.4rem 1.35rem 1.6rem;
  position:relative;
  text-align:center;
  box-shadow:0 6px 0 var(--main-soft),0 12px 28px rgba(108,179,255,.10);
  border:2px solid #fff;
  margin-top:14px;
}
.why-card__no{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  display:inline-flex;align-items:baseline;gap:.25rem;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  color:#fff;padding:.35rem 1rem .4rem;border-radius:999px;
  box-shadow:var(--shadow-sm);
  white-space:nowrap;
}
.why-card__no small{font-size:1rem;font-weight:800;letter-spacing:.1em}
.why-card__no strong{font-size:1.25rem;font-weight:900;letter-spacing:.02em;font-family:var(--font-alt)}
.why-card__ico{
  width:84px;height:84px;border-radius:50%;
  background:linear-gradient(135deg,var(--main-soft) 0%,#fff 100%);
  color:var(--main-deep);
  display:grid;place-items:center;
  margin:.5rem auto 1rem;
  border:3px dashed var(--main);
}
.why-card__title{
  font-size:1.3rem;font-weight:900;color:var(--sub-navy);
  line-height:1.55;letter-spacing:.02em;
  margin-bottom:.9rem;
}
.why-card__text{
  font-size:1rem;line-height:1.95;color:var(--text-sub);
  text-align:left;
}
.why-card__text strong{color:var(--sub-navy);font-weight:800;border-bottom:2px dotted var(--main)}

/* =========================================================
   PRICE
   ========================================================= */
.price-wrap{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:clamp(1.25rem,3vw,2rem);
  box-shadow:var(--shadow-soft);
  border:2px solid var(--main-soft);
}
.price-note{
  font-size:1rem;color:var(--text-sub);text-align:right;
  width:100%;
  max-width:720px;
  margin:0 auto .5rem;
  font-weight:700;
}
.price-table{
  width:100%;
  max-width:720px;
  margin-inline:auto;
  border-top:3px solid var(--main);
}
.price-table th,
.price-table td{
  padding:1.35rem .25rem;
  border-bottom:1.5px dashed var(--border);
  vertical-align:middle;text-align:left;
}
.price-table th{font-weight:700;color:var(--sub-navy);width:62%;padding-left:.25rem}
.price-table td{padding-right:.25rem}
.price-table__name{
  display:block;font-size:1.15rem;font-weight:900;color:var(--sub-navy);
  letter-spacing:.02em;line-height:1.5;margin-bottom:.3rem;
}
.price-table__desc{
  display:block;font-size:1rem;color:var(--text-sub);
  font-weight:500;line-height:1.7;
}
.price-table td{text-align:right;white-space:nowrap}
.price-table__num{
  font-size:1.75rem;font-weight:900;color:var(--main-deep);
  letter-spacing:.01em;font-family:var(--font-alt);
}
.price-table__num small{font-size:.6em;font-weight:800;margin-left:.05em}

.price-claim{
  display:grid;grid-template-columns:repeat(1,1fr);gap:.9rem;
  margin-top:1.75rem;padding-top:1.75rem;
  border-top:2px dashed var(--main-soft);
}
@media(min-width:680px){.price-claim{grid-template-columns:repeat(3,1fr);gap:1rem}}
.price-claim li{
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  text-align:center;padding:1.4rem 1rem 1.25rem;
  background:linear-gradient(180deg,#fff 0%,var(--main-pale) 100%);
  border-radius:var(--radius-sm);
  border:1.5px solid var(--main-soft);
  box-shadow:0 2px 0 var(--main-soft),0 6px 14px rgba(108,179,255,.08);
}
.price-claim__ico{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  display:flex;align-items:center;justify-content:center;
  color:#FFFFFF;
  flex-shrink:0;
  box-shadow:0 4px 12px rgba(47,79,125,.22),inset 0 -2px 0 rgba(0,0,0,.06);
  overflow:hidden;
}
.price-claim__ico svg{
  display:block;
  width:32px;height:32px;
  flex:0 0 auto;
  aspect-ratio:1/1;
  overflow:visible;
  transform:translateY(-0.9px);
}
.price-claim li strong{
  display:block;font-size:1.2rem;font-weight:900;
  color:var(--main-deep);letter-spacing:.02em;
  font-family:var(--font-alt);
  line-height:1.4;
}
.price-claim li span:not(.price-claim__ico){
  display:block;font-size:.95rem;color:var(--text-sub);
  font-weight:600;line-height:1.7;
}

/* =========================================================
   CTA MID
   ========================================================= */
.cta-mid{
  position:relative;
  padding:clamp(2.5rem,6vw,4rem) 0;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
}
.cta-mid__bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at 20% 0%, rgba(255,231,184,.4) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 100%, rgba(108,179,255,.4) 0%, transparent 50%),
    linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
}
.cta-mid__bg::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 2px 2px, rgba(255,255,255,.18) 1.5px, transparent 2px);
  background-size:32px 32px;opacity:.5;
}
.cta-mid__inner{
  text-align:center;
  max-width:920px;margin-inline:auto;
}
.cta-mid__ribbon{
  position:relative;
  left:50%;
  transform:translateX(-50%);
  width:min(1680px,94vw);
  max-width:94vw;
  margin:1rem 0 -3rem;
  line-height:0;
}
.cta-mid__ribbon-img{
  display:block;
  width:100%;
  height:auto;
}
@media(max-width:980px){
  .cta-mid__ribbon{
    width:min(1320px,94vw);
    max-width:94vw;
    margin:.8rem 0 -2.5rem;
  }
}
@media(max-width:600px){
  .cta-mid__ribbon{
    width:118vw;
    max-width:118vw;
    margin:.6rem 0 -3rem;
  }
}
@media(max-width:420px){
  .cta-mid__ribbon{
    width:122vw;
    max-width:122vw;
    margin:.5rem 0 -2.5rem;
  }
}
.cta-mid__title{
  font-size:clamp(1.85rem,4.6vw,2.5rem);
  font-weight:900;letter-spacing:.04em;
  margin-top:3rem;margin-bottom:.9rem;color:#fff;
  text-shadow:0 2px 0 rgba(0,0,0,.1);
  white-space:nowrap;
}
.cta-mid__title-deco{color:var(--warm);margin:0 .3em;font-size:1.2em}
.cta-mid__lead{
  font-size:1.05rem;line-height:1.85;
  color:rgba(255,255,255,.95);margin-bottom:1.75rem;
}
.cta-mid__price-em{
  color:var(--warm);font-weight:900;font-size:1.4em;letter-spacing:.02em;
}
.cta-mid__buttons{
  display:grid;grid-template-columns:1fr;gap:.75rem;
  max-width:900px;margin-inline:auto;
}
@media(min-width:560px){
  .cta-mid__buttons{grid-template-columns:repeat(2,1fr)}
  .cta-mid__buttons .cta-btn--tel{grid-column:1/-1}
}
@media(min-width:980px){
  .cta-mid__buttons{grid-template-columns:repeat(2,1fr)}
  .cta-mid__buttons .cta-btn--tel{grid-column:1/-1}
}
.cta-mid__buttons .cta-btn{
  background:#fff;color:var(--sub-navy);
  box-shadow:0 6px 0 0 rgba(0,0,0,.18),0 10px 24px rgba(0,0,0,.2);
}
.cta-mid__buttons .cta-btn--tel{
  background:linear-gradient(135deg,var(--tel) 0%,var(--tel-deep) 100%);color:#fff;
}
.cta-mid__buttons .cta-btn--line{
  background:linear-gradient(135deg,#08D058 0%,var(--line-deep) 100%);color:#fff;
}
.cta-mid__buttons .cta-btn--mail{
  background:#fff;color:var(--main-darker);
}
.cta-mid__buttons .cta-btn--mail .cta-btn__ico{background:var(--main-soft);color:var(--main-deep)}
.cta-mid__buttons .cta-btn--mail .cta-btn__sub{color:var(--text-sub)}
.cta-mid__buttons .cta-btn--form{
  background:#fff;color:var(--sub-navy);
}
.cta-mid__buttons .cta-btn--form .cta-btn__ico{background:rgba(47,79,125,.12);color:var(--sub-navy)}
.cta-mid__buttons .cta-btn--form .cta-btn__sub{color:var(--text-sub)}

.cta-mid__pay{
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:.5rem;margin-top:1.5rem;
}
.cta-mid__pay li{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.18);
  border:1.5px solid rgba(255,255,255,.4);
  color:#fff;
  padding:.45rem 1rem;border-radius:999px;
  font-size:1rem;font-weight:800;letter-spacing:.02em;
}
.cta-mid__pay-ico{
  display:inline-flex;align-items:center;justify-content:center;
  height:2rem;min-width:2rem;
  padding:.2rem .45rem;
  background:#fff;
  border-radius:6px;
  flex-shrink:0;
  overflow:hidden;
  box-shadow:0 1px 3px rgba(0,0,0,.12);
}
.cta-mid__pay-ico img{
  display:block;
  height:100%;width:auto;
  max-width:none;
  object-fit:contain;
}
.cta-mid__pay-ico--credit img{height:130%}
.cta-mid__pay-ico--paypay img{height:120%}
@media(max-width:600px){
  .cta-mid__pay{
    flex-direction:column;align-items:center;
    width:max-content;max-width:100%;margin-inline:auto;
  }
  .cta-mid__pay li{width:100%;justify-content:flex-start;white-space:nowrap}
}
.cta-mid__note{
  font-size:1rem;color:rgba(255,255,255,.85);
  margin-top:1rem;line-height:1.75;
}

/* =========================================================
   FLOW
   ========================================================= */
.flow-list{
  position:relative;
  display:grid;gap:1.25rem;
  max-width:880px;margin-inline:auto;
  padding-left:0;
}
@media(min-width:768px){
  .flow-list{padding-left:90px}
  .flow-list::before{
    content:"";position:absolute;
    left:42px;top:30px;bottom:30px;
    width:4px;
    background:repeating-linear-gradient(180deg,var(--main) 0 8px,transparent 8px 16px);
    border-radius:2px;
  }
}
.flow-item{
  position:relative;
  background:#fff;
  border-radius:var(--radius);
  padding:1.25rem 1.25rem 1.35rem;
  box-shadow:0 4px 0 var(--main-soft),0 8px 20px rgba(108,179,255,.08);
  border:2px solid #fff;
}
@media(min-width:768px){
  .flow-item{padding:1.5rem 1.75rem}
}
.flow-item__no{
  position:absolute;
  top:1rem;left:1rem;
  display:inline-flex;align-items:baseline;gap:.3rem;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  color:#fff;
  padding:.4rem 1rem;border-radius:999px;
  font-weight:900;line-height:1;
  box-shadow:var(--shadow-sm);
  letter-spacing:.04em;font-size:1rem;
}
.flow-item__no span{font-size:1rem;font-weight:800;letter-spacing:.08em;opacity:.9}
.flow-item__no strong{font-size:1.15rem;font-weight:900;letter-spacing:.02em;font-family:var(--font-alt)}
@media(min-width:768px){
  .flow-item__no{
    position:absolute;
    top:50%;left:-86px;transform:translateY(-50%);
    width:78px;height:78px;border-radius:50%;
    flex-direction:column;align-items:center;justify-content:center;
    padding:0;gap:0;font-size:1rem;
    border:4px solid #fff;
    box-shadow:0 6px 18px rgba(47,79,125,.2);
  }
  .flow-item__no span{font-size:1rem;letter-spacing:.08em}
  .flow-item__no strong{font-size:1.65rem;line-height:1}
}
.flow-item__body{padding-top:2.5rem}
@media(min-width:768px){.flow-item__body{padding-top:0}}
.flow-item__title{
  font-size:1.3rem;font-weight:900;color:var(--sub-navy);
  line-height:1.5;letter-spacing:.02em;
  margin-bottom:.55rem;
  padding-bottom:.65rem;
  border-bottom:2px dashed var(--main-soft);
}
.flow-item__text{
  font-size:1rem;line-height:1.95;color:var(--text-sub);
}
.flow-item__text strong{color:var(--main-deep);font-weight:800}

.flow-item__cta{
  margin-top:1.1rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.5rem;
}
.flow-item__cta .cta-btn{
  padding:.6rem .6rem;
  gap:.45rem;
  border-radius:var(--radius-sm);
  box-shadow:0 3px 0 0 rgba(0,0,0,.1),0 6px 14px rgba(0,0,0,.14);
  justify-content:flex-start;
  text-align:left;
}
.flow-item__cta .cta-btn--tel{
  grid-column:1 / -1;
  justify-content:center;
  text-align:center;
}
.flow-item__cta .cta-btn:hover{
  box-shadow:0 5px 0 0 rgba(0,0,0,.1),0 9px 18px rgba(0,0,0,.18);
}
.flow-item__cta .cta-btn__ico{
  width:32px;height:32px;
}
.flow-item__cta .cta-btn__ico svg{width:18px;height:18px}
.flow-item__cta .cta-btn__body{gap:0;min-width:0}
.flow-item__cta .cta-btn__main{
  font-size:.9rem;font-weight:900;line-height:1.25;letter-spacing:.01em;
  font-family:var(--font);
  white-space:nowrap;
}
.flow-item__cta .cta-btn--tel .cta-btn__main{
  font-size:1.25rem;letter-spacing:.04em;
  font-family:var(--font-alt);
}
@media(max-width:480px){
  .flow-item__cta{grid-template-columns:1fr;gap:.45rem}
  .flow-item__cta .cta-btn--tel{grid-column:auto}
  .flow-item__cta .cta-btn{padding:.6rem .85rem}
  .flow-item__cta .cta-btn--tel .cta-btn__main{font-size:1.2rem}
}

.flow-item__media{
  margin-top:1rem;
  display:flex;flex-direction:column;gap:.6rem;
}
.flow-item__media img{
  display:block;width:100%;height:auto;
  border-radius:var(--radius-sm);
  box-shadow:0 4px 14px rgba(47,79,125,.1);
  border:1px solid #fff;
}
.flow-item__media-sub{
  margin-top:.15rem;
  box-shadow:0 2px 8px rgba(47,79,125,.08)!important;
}
@media(min-width:768px){
  .flow-item{
    display:grid;
    grid-template-columns:1fr 280px;
    column-gap:1.5rem;
    row-gap:0;
    align-items:start;
  }
  .flow-item__body{grid-column:1}
  .flow-item__media{
    grid-column:2;
    margin-top:0;
  }
}
@media(min-width:768px) and (max-width:980px){
  .flow-item{grid-template-columns:1fr 240px}
}

/* =========================================================
   CASES
   ========================================================= */
.cases-grid{
  display:grid;gap:1.25rem;
  grid-template-columns:repeat(1,1fr);
}
@media(min-width:560px){.cases-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.cases-grid{grid-template-columns:repeat(4,1fr)}}

.case-card{
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 4px 0 var(--main-soft),0 8px 20px rgba(108,179,255,.08);
  transition:transform var(--t-fast),box-shadow var(--t-fast);
  border:2px solid #fff;
}
.case-card:hover{
  transform:translateY(-4px);
  box-shadow:0 8px 0 var(--main-soft),0 16px 32px rgba(108,179,255,.16);
  border-color:var(--main);
}
.case-card__shot{
  position:relative;margin:10px 10px 0;
  aspect-ratio:4/3;overflow:hidden;
  border-radius:var(--radius-sm);
}
.case-card__shot img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s var(--ease);
}
.case-card:hover .case-card__shot img{transform:scale(1.06)}
.case-card__area{
  position:absolute;top:8px;left:8px;
  background:var(--main-deep);color:#fff;
  font-size:1rem;font-weight:900;letter-spacing:.05em;
  padding:.3rem .9rem;border-radius:999px;
  box-shadow:0 4px 12px rgba(47,79,125,.3);
}
.case-card__body{padding:1.1rem 1.1rem 1.2rem;display:flex;flex-direction:column;flex:1}
.case-card__title{
  font-size:1.1rem;font-weight:900;color:var(--sub-navy);
  line-height:1.6;letter-spacing:.01em;margin-bottom:.85rem;
}
.case-card__meta{
  display:grid;gap:.3rem;margin-bottom:.95rem;flex:1;
}
.case-card__meta div{
  display:grid;grid-template-columns:5em 1fr;gap:.5rem;
  font-size:1rem;
  padding:.35rem 0;border-bottom:1px dashed var(--border-soft);
}
.case-card__meta dt{color:var(--text-mute);font-weight:800;margin:0}
.case-card__meta dd{margin:0;color:var(--text);font-weight:800;text-align:right}
.case-card__price{
  display:flex;align-items:baseline;justify-content:space-between;
  background:var(--main-soft);
  border-radius:var(--radius-sm);padding:.7rem .95rem;
  margin-top:auto;
}
.case-card__price span{font-size:1rem;color:var(--main-darker);font-weight:800}
.case-card__price strong{
  font-size:1.4rem;font-weight:900;color:var(--main-deep);
  letter-spacing:.01em;font-family:var(--font-alt);
}
.case-card__price strong small{font-size:.75em;font-weight:800;margin-left:.05em}

.cases-more{text-align:center;margin-top:1.75rem}
.cases-more__link{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.85rem;
  background:#fff;color:var(--main-deep);
  border:2.5px solid var(--main);
  border-radius:999px;
  font-weight:800;font-size:1.05rem;letter-spacing:.02em;
  transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast);
  box-shadow:0 4px 0 var(--main-soft);
}
.cases-more__link:hover{
  background:var(--main-deep);color:#fff;transform:translateY(-2px);
  box-shadow:0 6px 0 var(--main-soft);
}
.cases-more__link span{transition:transform var(--t-fast)}
.cases-more__link:hover span{transform:translateX(3px)}

/* =========================================================
   VOICE
   ========================================================= */
.voice-em{
  color:var(--main-deep);font-size:1.5em;font-weight:900;
  letter-spacing:.02em;margin:0 .25em;
  font-family:var(--font-alt);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  vertical-align:middle;
  line-height:1;
  padding:.55em 8px .5em;
  background:url("./img_label.png") center/100% 100% no-repeat;
}
.voice-em small{font-size:.5em;font-weight:800;margin-left:.05em}
.voice-grid{
  display:grid;gap:1.25rem;
  grid-template-columns:repeat(1,1fr);
  margin-bottom:1.5rem;
}
@media(min-width:768px){.voice-grid{grid-template-columns:repeat(3,1fr)}}
.voice-card{
  background:#fff;color:var(--text);
  border-radius:var(--radius);
  padding:1.4rem 1.25rem 1.25rem;
  position:relative;
  box-shadow:0 6px 0 rgba(255,231,184,.5),0 12px 28px rgba(47,79,125,.08);
  border:2px solid #fff;
}
.voice-card::before{
  content:"\201C";
  position:absolute;top:-.5rem;right:1rem;
  font-size:4rem;line-height:1;
  color:var(--main);font-weight:900;
  opacity:.5;
}
.voice-card__rate{
  color:#FFB422;font-size:1.15rem;letter-spacing:.12em;
  font-weight:900;margin-bottom:.55rem;line-height:1;
}
.voice-card__title{
  font-size:1.15rem;font-weight:900;color:var(--sub-navy);
  line-height:1.6;letter-spacing:.01em;margin-bottom:.7rem;
  padding-bottom:.7rem;border-bottom:2px dashed var(--main-soft);
}
.voice-card__text{
  font-size:1rem;line-height:1.95;color:var(--text-sub);
  margin-bottom:.9rem;
}
.voice-card__who{
  font-size:1rem;color:var(--text-mute);font-weight:800;
}

/* ---- voice gallery (横並び 2段) ---- */
.voice-gallery{
  margin-top:2rem;
  display:grid;gap:1rem;
}
.voice-gallery__row{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:.6rem;
  align-items:stretch;
}
.voice-gallery__row li{
  background:#fff;
  border-radius:var(--radius-sm);
  overflow:hidden;
  border:2px solid #fff;
  box-shadow:0 4px 14px rgba(47,79,125,.08);
}
.voice-gallery__row img{
  display:block;width:100%;height:100%;
  object-fit:cover;
}
.voice-gallery__row--photo li{aspect-ratio:1/1}
.voice-gallery__row--text li{aspect-ratio:1/1;background:var(--main-pale)}
.voice-gallery__row--text img{object-fit:contain;padding:.25rem}

@media(max-width:980px){
  .voice-gallery__row{grid-template-columns:repeat(4,1fr);gap:.55rem}
}
@media(max-width:600px){
  .voice-gallery__row{grid-template-columns:repeat(3,1fr);gap:.5rem}
}
@media(max-width:420px){
  .voice-gallery__row{grid-template-columns:repeat(2,1fr)}
}

/* =========================================================
   FAQ
   ========================================================= */
.faq-list{display:grid;gap:.85rem}
.faq-item{
  background:#fff;
  border-radius:var(--radius);
  overflow:hidden;
  transition:box-shadow var(--t-fast);
  box-shadow:0 3px 0 var(--main-soft),0 6px 14px rgba(108,179,255,.06);
  border:2px solid #fff;
}
.faq-item[open]{
  border-color:var(--main);
  box-shadow:0 5px 0 var(--main-soft),0 10px 22px rgba(108,179,255,.12);
}
.faq-item summary{
  list-style:none;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;gap:.85rem;
  padding:1.1rem 1.1rem;
  cursor:pointer;
  font-weight:800;color:var(--sub-navy);
  line-height:1.5;letter-spacing:.01em;
  user-select:none;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item__q{
  display:inline-grid;place-items:center;
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--main) 0%,var(--main-deep) 100%);
  color:#fff;font-weight:900;font-size:1.1rem;
  font-family:var(--font-alt);
  flex-shrink:0;
}
.faq-item__qtext{font-size:1.05rem;line-height:1.6}
.faq-item__toggle{
  position:relative;
  width:20px;height:20px;flex-shrink:0;
}
.faq-item__toggle::before,
.faq-item__toggle::after{
  content:"";position:absolute;background:var(--main-deep);
  transition:transform var(--t-fast);
  border-radius:2px;
}
.faq-item__toggle::before{
  left:0;right:0;top:9px;height:2.5px;
}
.faq-item__toggle::after{
  top:0;bottom:0;left:9px;width:2.5px;
}
.faq-item[open] .faq-item__toggle::after{transform:scaleY(0)}
.faq-item__body{
  display:grid;grid-template-columns:auto 1fr;gap:.85rem;
  padding:1rem 1.1rem 1.2rem;
  border-top:2px dashed var(--main-soft);
  align-items:flex-start;
}
.faq-item__a{
  display:inline-grid;place-items:center;
  width:42px;height:42px;border-radius:50%;
  background:var(--warm);
  color:var(--warm-deep);font-weight:900;font-size:1.1rem;
  font-family:var(--font-alt);
  flex-shrink:0;
}
.faq-item__body p{
  font-size:1rem;line-height:1.95;color:var(--text-sub);
  padding-top:.5rem;
}

/* =========================================================
   NOTICE
   ========================================================= */
.notice-head{
  display:flex;align-items:center;gap:.85rem;
  margin-bottom:1rem;
  padding-bottom:.85rem;border-bottom:2px solid var(--warn);
}
.notice-head__icon{
  display:inline-grid;place-items:center;
  width:42px;height:42px;border-radius:50%;
  background:var(--warn);color:#fff;font-weight:900;font-size:1.25rem;
  flex-shrink:0;
}
.notice-head__title{
  font-size:1.3rem;font-weight:900;color:var(--warn);
  letter-spacing:.02em;
}
.notice-list{
  display:grid;gap:.55rem;
  padding-left:1.5rem;
}
.notice-list li{
  font-size:1rem;line-height:1.9;color:var(--text-sub);
  font-weight:500;
  list-style:disc;list-style-position:outside;
}
.notice-list li::marker{color:var(--main)}

/* =========================================================
   FINAL CTA
   ========================================================= */
.cta-final{
  position:relative;
  padding:clamp(3rem,7vw,5rem) 0;
  color:#fff;
  overflow:hidden;
  isolation:isolate;
  text-align:center;
}
.cta-final__bg{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,231,184,.35) 0%, transparent 55%),
    linear-gradient(180deg,var(--main-deep) 0%,var(--main-darker) 100%);
}
.cta-final__bg::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 2px 2px, rgba(255,255,255,.15) 1.5px, transparent 2px);
  background-size:28px 28px;opacity:.6;
}
.cta-final__eyebrow{
  font-size:1rem;font-weight:900;letter-spacing:.2em;
  color:var(--warm);margin-bottom:1rem;
}
.cta-final__title{
  font-size:clamp(1.75rem,4.2vw,2.35rem);
  font-weight:900;letter-spacing:.03em;
  line-height:1.55;margin-bottom:1rem;
  color:#fff;
}
.cta-final__brand{
  color:var(--warm);
  position:relative;display:inline-block;
}
.cta-final__lead{
  font-size:1.05rem;line-height:1.95;
  color:rgba(255,255,255,.95);
  max-width:42em;margin:0 auto 2rem;
}
.cta-final__buttons{
  display:grid;grid-template-columns:1fr;gap:.75rem;
  max-width:900px;margin-inline:auto;
}
@media(min-width:560px){
  .cta-final__buttons{grid-template-columns:repeat(2,1fr)}
  .cta-final__buttons .cta-btn--tel{grid-column:1/-1}
}
@media(min-width:980px){
  .cta-final__buttons{grid-template-columns:repeat(2,1fr)}
  .cta-final__buttons .cta-btn--tel{grid-column:1/-1}
}
.cta-final__buttons .cta-btn--mail{
  background:#fff;color:var(--main-darker);
}
.cta-final__buttons .cta-btn--mail .cta-btn__ico{background:var(--main-soft);color:var(--main-deep)}
.cta-final__buttons .cta-btn--mail .cta-btn__sub{color:var(--text-sub)}
.cta-final__buttons .cta-btn--form{
  background:#fff;color:var(--sub-navy);
}
.cta-final__buttons .cta-btn--form .cta-btn__ico{background:rgba(47,79,125,.12);color:var(--sub-navy)}
.cta-final__buttons .cta-btn--form .cta-btn__sub{color:var(--text-sub)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  background:var(--sub-navy);color:rgba(255,255,255,.9);
  font-size:1rem;
}
.site-footer__top{
  padding:clamp(2rem,5vw,3rem) 0 1.5rem;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-footer__top-inner{
  display:grid;gap:2rem;
  grid-template-columns:1fr;
}
@media(min-width:768px){
  .site-footer__top-inner{grid-template-columns:1fr 1.4fr}
}
.site-footer__brand-name{
  font-size:1.3rem;font-weight:900;color:#fff;
  letter-spacing:.04em;margin-bottom:.55rem;
}
.site-footer__brand-text{
  font-size:1rem;line-height:1.9;color:rgba(255,255,255,.78);
}
.site-footer__nav{
  display:block;
}
.site-footer__nav-title{
  font-size:1.05rem;font-weight:900;color:var(--main);
  letter-spacing:.06em;margin-bottom:.9rem;
  padding-bottom:.45rem;border-bottom:1.5px solid rgba(108,179,255,.4);
}
.site-footer__nav-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.55rem 1.25rem;
}
@media(min-width:680px){
  .site-footer__nav-list{grid-template-columns:repeat(4,minmax(0,1fr))}
}
.site-footer__nav a{
  color:rgba(255,255,255,.82);font-size:1rem;
  font-weight:600;
  display:inline-block;
  padding:.15rem 0;
}
.site-footer__nav a:hover{color:var(--main)}

/* ----- Sitemap ----- */
.site-footer__sitemap{
  padding:clamp(2rem,5vw,3rem) 0 clamp(1.75rem,4vw,2.5rem);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-footer__sitemap-grid{
  display:grid;
  gap:1.5rem;
  grid-template-columns:1fr;
}
@media(min-width:560px){
  .site-footer__sitemap-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem 1.75rem}
}
@media(min-width:900px){
  .site-footer__sitemap-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem 1.75rem}
}
.site-footer__sitemap-col{display:flex;flex-direction:column}
.site-footer__sitemap-title{
  font-size:1rem;
  font-weight:900;
  color:var(--main);
  letter-spacing:.06em;
  margin:0 0 .85rem;
  padding-bottom:.45rem;
  border-bottom:1.5px solid rgba(108,179,255,.4);
}
.site-footer__sitemap-col ul + .site-footer__sitemap-title{
  margin-top:1.5rem;
}
.site-footer__sitemap-col ul{display:grid;gap:.4rem}
.site-footer__sitemap-col a{
  display:inline-block;
  font-size:.92rem;
  font-weight:500;
  color:rgba(255,255,255,.78);
  line-height:1.5;
  padding:.12rem 0 .12rem 1rem;
  position:relative;
}
.site-footer__sitemap-col a::before{
  content:"";
  position:absolute;
  left:0;top:.7em;
  width:.4rem;height:.4rem;
  border-top:1.5px solid var(--main);
  border-right:1.5px solid var(--main);
  transform:rotate(45deg);
}
.site-footer__sitemap-col a:hover{color:var(--main)}
.site-footer__sitemap-col--main ul{gap:.55rem}
.site-footer__sitemap-col--main a{
  font-weight:700;
  font-size:.95rem;
  color:rgba(255,255,255,.92);
}

.site-footer__company{
  padding:2.25rem 0 2rem;
  background:rgba(0,0,0,.18);
}
.site-footer__company-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.25rem;
  flex-wrap:wrap;
  padding-bottom:1.4rem;
  margin-bottom:1.5rem;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.site-footer__company-logo{
  display:inline-flex;
  flex-direction:column;
  line-height:1.1;
  color:#fff;
}
.site-footer__company-logo:hover{color:var(--main)}
.site-footer__company-logo-en{
  font-size:1.7rem;
  font-weight:900;
  letter-spacing:.06em;
  font-family:var(--font-alt);
}
.site-footer__company-logo-jp{
  font-size:.85rem;
  font-weight:700;
  color:var(--main);
  letter-spacing:.18em;
  margin-top:.2rem;
}
.site-footer__social{
  display:flex;
  align-items:center;
  gap:.6rem;
}
.site-footer__social a{
  display:inline-grid;
  place-items:center;
  width:40px;height:40px;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  transition:background var(--t-fast),transform var(--t-fast),border-color var(--t-fast);
}
.site-footer__social a:hover{
  background:var(--main);
  border-color:var(--main);
  color:#fff;
  transform:translateY(-2px);
}
.site-footer__social svg{display:block}
.site-footer__social i{font-size:1.15rem;line-height:1}

.site-footer__company-list{
  display:grid;gap:.45rem;margin:0 0 1.1rem;
  grid-template-columns:1fr;
}
@media(min-width:680px){
  .site-footer__company-list{grid-template-columns:1fr 1fr}
}
.site-footer__company-list div{
  display:grid;grid-template-columns:7em 1fr;gap:.55rem;
  font-size:1rem;line-height:1.75;
  padding:.35rem 0;
  border-bottom:1px dashed rgba(255,255,255,.12);
}
.site-footer__company-list dt{color:var(--main);font-weight:800;margin:0}
.site-footer__company-list dd{color:rgba(255,255,255,.88);font-weight:500;margin:0}
.site-footer__licenses{
  display:grid;gap:.35rem;
  font-size:1rem;color:rgba(255,255,255,.72);
  line-height:1.8;
  padding-top:.9rem;
  border-top:1px solid rgba(255,255,255,.08);
}
.site-footer__licenses li{padding-left:.85rem;position:relative}
.site-footer__licenses li::before{
  content:"";position:absolute;left:0;top:.7em;
  width:.4rem;height:.4rem;background:var(--main);
  border-radius:50%;
}

.site-footer__bottom{
  padding:1.1rem 0;
  background:rgba(0,0,0,.32);
}
.site-footer__bottom-inner{
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:space-between;gap:.85rem;
  font-size:1rem;color:rgba(255,255,255,.65);
}
.site-footer__copy{margin:0;letter-spacing:.04em}
.site-footer__privacy{
  display:inline-flex;
  align-items:center;
  margin:0;
}
.site-footer__privacy-img{
  display:block;
  height:auto;
  width:auto;
  max-height:54px;
}
@media(max-width:560px){
  .site-footer__company-head{justify-content:center;text-align:center}
  .site-footer__bottom-inner{justify-content:center;text-align:center}
  .site-footer__privacy-img{max-height:44px}
}

/* =========================================================
   FIXED MOBILE CTA
   ========================================================= */
.fixed-cta{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:80;
  background:rgba(255,255,255,.95);
  border-top:2px solid var(--main-soft);
  backdrop-filter:blur(8px);
  padding:.5rem;
  gap:.4rem;
  box-shadow:0 -8px 24px rgba(47,79,125,.18);
}
@media(max-width:899px){
  .fixed-cta{display:flex}
  body{padding-bottom:72px}
}
.fixed-cta__btn{
  flex:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.2rem;
  padding:.6rem .4rem;border-radius:var(--radius-sm);
  color:#fff;font-size:1rem;font-weight:900;
  box-shadow:0 4px 12px rgba(0,0,0,.2);
  line-height:1.15;letter-spacing:.02em;
}
.fixed-cta__btn--tel{background:linear-gradient(135deg,var(--tel) 0%,var(--tel-deep) 100%)}
.fixed-cta__btn--line{background:linear-gradient(135deg,#08D058 0%,var(--line-deep) 100%)}
.fixed-cta__btn--mail{background:linear-gradient(135deg,var(--main-deep) 0%,var(--main-darker) 100%)}
.fixed-cta__btn--form{background:linear-gradient(135deg,var(--sub-navy) 0%,#1F3556 100%)}
@media(max-width:560px){
  .fixed-cta__btn{padding:.5rem .25rem;font-size:1rem;letter-spacing:.01em}
  .fixed-cta__ico{width:22px;height:22px}
  .fixed-cta__ico svg{width:18px;height:18px}
}
.fixed-cta__ico{
  display:inline-grid;place-items:center;
  width:24px;height:24px;
}

/* =========================================================
   PRINT
   ========================================================= */
@media print{
  .site-header,.page-nav,.fixed-cta,.cta-mid,.cta-final{display:none}
  .hero{background:#fff;color:#000}
  .hero__bg{display:none}
}

/* =========================================================
   PREFERS REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    transition:none!important;animation:none!important;
  }
  html{scroll-behavior:auto}
}

/* =========================================================
   MOBILE FONT-SIZE POLICY (max 24px / p = 16px)
   ========================================================= */
@media(max-width:600px){
  /* body copy paragraphs = 16px */
  .hero p,.section p,.cta-mid p,.cta-final p,.site-footer p{font-size:16px}
  /* keep compact label/badge chips at their designed size */
  .hero p.hero__chip{font-size:.82rem}

  /* cap large display text to 24px */
  .sec-head__title,
  .cta-mid__title,
  .cta-final__title,
  .price-table__num,
  .hero__visual-stat-num,
  .site-footer__company-logo-en{font-size:24px}
  /* hero main title: slightly larger for emphasis */
  .hero__title{font-size:27px}
  .hero__title-main{font-size:27px}
  .hero__title-mark{font-size:17px}
  .cta-btn--tel .cta-btn__main,
  .cta-btn--lg.cta-btn--tel .cta-btn__main{font-size:24px}
  .trust-bar__name strong{font-size:24px}
  .cta-mid__title-deco{font-size:24px}
  .voice-card::before{font-size:24px}
}
