/* ============================================
   クレアマネジメント 公式HP 共通スタイル
   - Mobile First / 信頼感のあるコーポレートデザイン
   - Brand: ピンク (#E89AAE) × グリーン (#8BC272) × 白 × 濃グレー
   ============================================ */

:root{
  --color-brand: #E89AAE;
  --color-brand-deep: #C9627E;
  --color-brand-soft: #FBEDF2;
  --color-brand-pale: #FFF8FA;
  --color-leaf: #A8C68E;
  --color-leaf-deep: #6E9B53;
  --color-trust: #4A5874;
  --color-trust-light: #EEF1F7;
  --color-cream: #FBF6F1;
  --color-cream-deep: #F5ECE3;
  --color-gold: #C9A063;
  --color-bg: #FFFFFF;
  --color-bg-alt: #FBF6F1;
  --color-text: #2E2A33;
  --color-text-mute: #67616D;
  --color-border: #ECE3DC;
  --color-warning-bg: #FFF7E6;
  --color-warning-border: #F0C674;
  --font-jp: "Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","YuGothic","Meiryo",system-ui,sans-serif;
  --font-en: "Helvetica Neue",Arial,sans-serif;
  --radius: 12px;
  --shadow-card: 0 2px 12px rgba(0,0,0,.06);
  --shadow-hover: 0 6px 20px rgba(232,154,174,.18);
  --container: 1080px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-jp);
  color:var(--color-text);
  background:var(--color-bg);
  line-height:1.8;
  -webkit-text-size-adjust:100%;
  font-feature-settings:"palt";
}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-brand-deep);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.4;font-weight:700;margin:0 0 .8em}
p{margin:0 0 1em}
ul,ol{padding-left:1.4em;margin:0 0 1em}
li{margin-bottom:.3em}
hr{border:0;border-top:1px solid var(--color-border);margin:2em 0}

.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.section{padding:60px 0}
.section--alt{background:var(--color-bg-alt)}
.section--brand{background:var(--color-brand-soft)}
.section-title{
  font-size:1.5rem;
  text-align:center;
  position:relative;
  padding-bottom:.6em;
  margin-bottom:1.5em;
}
.section-title::after{
  content:"";
  display:block;
  width:48px;height:3px;
  background:var(--color-brand);
  border-radius:2px;
  margin:.5em auto 0;
}
.section-lead{text-align:center;color:var(--color-text-mute);margin-bottom:2em}

/* ========== Header ========== */
.site-header{
  position:sticky;top:0;z-index:50;
  --site-header-height:124px;
  background:rgba(255,255,255,.96);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--color-border);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 20px;max-width:var(--container);margin:0 auto;
}
.site-logo{display:flex;align-items:center;gap:10px;min-width:0}
.site-logo img{
  height:104px;width:auto;max-width:min(300px,64vw);
  object-fit:contain;display:block;
}
.site-logo__text{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.site-logo__text small{display:block;font-size:.65rem;color:var(--color-text-mute);letter-spacing:.15em}

.global-nav{display:none}
.global-nav__list{list-style:none;display:flex;gap:18px;padding:0;margin:0;align-items:center}
.global-nav__list a{color:var(--color-text);font-size:.92rem;font-weight:500}
.global-nav__list a:hover{color:var(--color-brand-deep);text-decoration:none}
.global-nav__cta{
  background:var(--color-brand);color:#fff !important;
  padding:8px 16px;border-radius:999px;font-weight:700;
  transition:background .2s;
}
.global-nav__cta:hover{background:var(--color-brand-deep);text-decoration:none}

.nav-toggle{
  display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border:0;background:transparent;
  cursor:pointer;color:var(--color-text);
}
.nav-toggle__bar{
  display:block;width:24px;height:2px;background:currentColor;
  position:relative;transition:all .2s;
}
.nav-toggle__bar::before,
.nav-toggle__bar::after{
  content:"";position:absolute;left:0;width:24px;height:2px;background:currentColor;
  transition:all .2s;
}
.nav-toggle__bar::before{top:-7px}
.nav-toggle__bar::after{top:7px}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar::after{top:0;transform:rotate(-45deg)}

.mobile-nav{
  display:none;
  position:fixed;top:var(--site-header-height);left:0;right:0;bottom:0;
  background:#fff;padding:20px;overflow-y:auto;z-index:40;
  border-top:1px solid var(--color-border);
}
.mobile-nav.is-open{display:block}
.mobile-nav__list{list-style:none;padding:0;margin:0}
.mobile-nav__list li{border-bottom:1px solid var(--color-border)}
.mobile-nav__list a{
  display:block;padding:16px 4px;color:var(--color-text);
  font-size:1rem;font-weight:500;
}
.mobile-nav__cta{
  margin-top:24px;display:block;text-align:center;
  background:var(--color-brand);color:#fff !important;
  padding:14px;border-radius:999px;font-weight:700;
}

/* ========== Hero ========== */
.hero{
  position:relative;
  background:
    radial-gradient(circle at 80% 10%,var(--color-brand-soft) 0%,transparent 45%),
    radial-gradient(circle at 10% 90%,var(--color-cream-deep) 0%,transparent 50%),
    linear-gradient(180deg,var(--color-cream) 0%,#fff 100%);
  padding:48px 20px 56px;
  overflow:hidden;
}
.hero__inner{position:relative;z-index:2}
.hero--with-photo{padding-bottom:0}
.hero--with-photo .hero__photo{
  margin:32px auto 0;max-width:920px;border-radius:18px;overflow:hidden;
  box-shadow:0 10px 40px rgba(201,98,126,.18);
  border:6px solid #fff;
}
.hero--with-photo .hero__photo img{display:block;width:100%;height:auto}
.hero__ornament{
  position:absolute;pointer-events:none;opacity:.7;z-index:1;
}
.hero__ornament--leaf-a{
  top:10px;left:-30px;width:140px;height:140px;
  background:radial-gradient(circle at 30% 30%,var(--color-leaf) 0%,transparent 60%);
  filter:blur(20px);
}
.hero__ornament--leaf-b{
  top:60px;right:-40px;width:180px;height:180px;
  background:radial-gradient(circle at 70% 30%,var(--color-brand) 0%,transparent 60%);
  filter:blur(28px);opacity:.4;
}
.hero--centered{text-align:center}
.hero__inner{max-width:780px;margin:0 auto}
.hero__eyebrow{
  color:var(--color-brand-deep);font-weight:700;
  letter-spacing:.18em;font-size:.78rem;margin-bottom:.8em;
}
.hero__title{
  font-size:1.8rem;line-height:1.45;margin-bottom:.6em;
}
.hero__title span{color:var(--color-brand-deep)}
.hero__desc{color:var(--color-text-mute);font-size:1rem;margin-bottom:1.8em}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

.btn{
  display:inline-block;padding:14px 28px;border-radius:999px;
  font-weight:700;font-size:.95rem;text-align:center;
  transition:transform .15s,box-shadow .15s,background .2s;
  border:0;cursor:pointer;line-height:1.2;
}
.btn--primary{background:var(--color-brand);color:#fff !important}
.btn--primary:hover{background:var(--color-brand-deep);text-decoration:none;transform:translateY(-1px);box-shadow:var(--shadow-hover)}
.btn--ghost{background:#fff;color:var(--color-text) !important;border:1.5px solid var(--color-border)}
.btn--ghost:hover{border-color:var(--color-brand);color:var(--color-brand-deep) !important;text-decoration:none}
.btn--block{display:block;width:100%}

/* ========== Visual top page refresh ========== */
.hero--visual{
  min-height:560px;
  padding:72px 20px 78px;
  display:flex;
  align-items:center;
  background:#2B3444;
  color:#fff;
}
.hero--visual .hero__media,
.hero--visual .hero__shade{
  position:absolute;inset:0;
}
.hero--visual .hero__media img{
  width:100%;height:100%;object-fit:cover;object-position:center;
}
.hero--visual .hero__shade{
  background:
    linear-gradient(90deg,rgba(30,33,42,.88) 0%,rgba(48,45,55,.68) 38%,rgba(48,45,55,.18) 78%,rgba(48,45,55,.08) 100%),
    linear-gradient(180deg,rgba(0,0,0,.12) 0%,rgba(0,0,0,.34) 100%);
  z-index:1;
}
.hero__inner--visual{
  max-width:var(--container);
  width:100%;
  text-align:left;
}
.hero--visual .hero__eyebrow{color:#FFE3EC}
.hero--visual .hero__title{
  color:#fff;
  max-width:700px;
  text-shadow:0 2px 18px rgba(0,0,0,.22);
}
.hero--visual .hero__title span{color:#FFD8E3}
.hero--visual .hero__desc{
  color:rgba(255,255,255,.9);
  max-width:680px;
  text-shadow:0 1px 12px rgba(0,0,0,.2);
}
.hero--visual .hero__cta{justify-content:flex-start}
.hero--visual .btn--ghost{
  background:rgba(255,255,255,.13);
  color:#fff !important;
  border-color:rgba(255,255,255,.46);
  backdrop-filter:blur(8px);
}
.hero__badges{
  display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;
}
.hero__badges span{
  display:inline-flex;align-items:center;min-height:34px;
  padding:7px 13px;border-radius:999px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.28);
  color:#fff;font-weight:700;font-size:.82rem;
  backdrop-filter:blur(8px);
}
.proof-strip{
  position:relative;
  z-index:3;
  margin-top:-34px;
  padding:0 0 34px;
}
.proof-strip__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.proof-card{
  display:grid;
  grid-template-columns:104px 1fr;
  gap:14px;
  align-items:center;
  background:#fff;
  border:1px solid rgba(236,227,220,.9);
  border-radius:10px;
  box-shadow:0 10px 30px rgba(42,42,42,.1);
  overflow:hidden;
}
.proof-card img{
  width:104px;height:100%;min-height:104px;object-fit:cover;
}
.proof-card div{padding:14px 14px 14px 0}
.proof-card strong{
  display:block;font-size:.94rem;margin-bottom:4px;color:var(--color-text);
}
.proof-card span{
  display:block;color:var(--color-text-mute);font-size:.82rem;line-height:1.6;
}
.pillar__media{
  margin:-28px -24px 20px;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--color-brand-pale);
}
.pillar__media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.pillar:hover .pillar__media img{transform:scale(1.035)}
.trouble-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:22px;
  align-items:center;
}
.trouble-visual{
  margin:0;
  background:#fff;
  border:1px solid var(--color-border);
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 12px 30px rgba(74,88,116,.1);
}
.trouble-visual img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}
.trouble-visual figcaption{
  padding:14px 16px;
  color:var(--color-text-mute);
  font-size:.86rem;
  line-height:1.65;
}
.stat__icon{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:48px;height:28px;padding:0 9px;margin-bottom:10px;
  border-radius:999px;
  background:var(--color-trust-light);
  color:var(--color-trust);
  font-size:.75rem;font-weight:700;
}
.cta-bar--photo{
  position:relative;overflow:hidden;background:#3F4350;
}
.cta-bar--photo .cta-bar__bg{
  position:absolute;inset:0;z-index:0;
}
.cta-bar--photo .cta-bar__bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(50,40,50,.88) 0%,rgba(62,47,61,.72) 48%,rgba(62,47,61,.45) 100%),
    linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.35) 100%);
}
.cta-bar--photo .cta-bar__bg img{
  width:100%;height:100%;object-fit:cover;object-position:center;
}
.cta-bar--photo .container{position:relative;z-index:1}
.cta-bar__eyebrow{
  color:#FFE3EC;
  font-family:var(--font-en);
  letter-spacing:.18em;
  font-weight:700;
  font-size:.76rem;
  margin-bottom:.6em;
}

/* ========== Cards / Grids ========== */
.grid{display:grid;gap:20px;grid-template-columns:1fr}
.card{
  background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);
  padding:24px;transition:transform .2s,box-shadow .2s;
  overflow:hidden;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.card__icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--color-brand-soft);color:var(--color-brand-deep);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;font-weight:700;margin-bottom:.8em;
}
.card__title{font-size:1.1rem;margin-bottom:.4em}
.card__text{color:var(--color-text-mute);font-size:.92rem;margin:0}
.card a.card__more{
  display:inline-block;margin-top:.8em;color:var(--color-brand-deep);
  font-weight:600;font-size:.9rem;
}
/* photo card */
.card--photo{padding:0;display:flex;flex-direction:column}
.card--photo .card__photo{
  aspect-ratio:4/3;overflow:hidden;background:var(--color-brand-pale);
}
.card--photo .card__photo img{
  display:block;width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;
}
.card--photo:hover .card__photo img{transform:scale(1.04)}
.card--photo .card__body{padding:22px 22px 24px}
.card--photo .card__title{margin-top:0}

/* ========== Service items / Feature lists ========== */
.feature-list{list-style:none;padding:0}
.feature-list li{
  padding:18px 16px 18px 52px;background:#fff;
  border:1px solid var(--color-border);border-radius:var(--radius);
  margin-bottom:12px;position:relative;
}
.feature-list li::before{
  content:"";position:absolute;left:18px;top:22px;
  width:20px;height:20px;border-radius:50%;
  background:var(--color-leaf);
  background-image:linear-gradient(135deg,transparent 45%,#fff 45%,#fff 55%,transparent 55%),linear-gradient(45deg,transparent 45%,#fff 45%,#fff 55%,transparent 55%);
}
.feature-list strong{display:block;margin-bottom:.2em;font-size:1.02rem}
.feature-list small{color:var(--color-text-mute)}

/* ========== Steps ========== */
.steps{counter-reset:step;list-style:none;padding:0}
.steps li{
  counter-increment:step;background:#fff;border:1px solid var(--color-border);
  border-radius:var(--radius);padding:20px 20px 20px 70px;
  margin-bottom:14px;position:relative;
}
.steps li::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;left:18px;top:18px;
  width:38px;height:38px;border-radius:50%;
  background:var(--color-brand);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.9rem;font-family:var(--font-en);
}
.steps strong{display:block;font-size:1.05rem;margin-bottom:.3em}

/* ========== Tables ========== */
.info-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--color-border)}
.info-table th,.info-table td{
  text-align:left;padding:14px 16px;font-size:.95rem;
  border-bottom:1px solid var(--color-border);vertical-align:top;
}
.info-table th{
  background:var(--color-bg-alt);font-weight:600;width:32%;
  color:var(--color-text);
}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:0}

/* ========== Breadcrumbs ========== */
.breadcrumbs{
  font-size:.82rem;color:var(--color-text-mute);
  padding:14px 20px;max-width:var(--container);margin:0 auto;
}
.breadcrumbs ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.breadcrumbs li::after{content:"›";margin-left:6px;color:var(--color-text-mute)}
.breadcrumbs li:last-child::after{content:""}
.breadcrumbs a{color:var(--color-text-mute)}

/* ========== Page header ========== */
.page-header{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--color-cream) 0%,#fff 100%);
  padding:36px 20px;text-align:center;
  border-bottom:1px solid var(--color-border);
}
.page-header__inner{position:relative;z-index:2}
.page-header--with-photo{
  background:none;padding:0;
}
.page-header--with-photo .page-header__bg{
  position:absolute;inset:0;z-index:1;
}
.page-header--with-photo .page-header__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.55) 0%,rgba(255,248,250,.92) 100%);
}
.page-header--with-photo .page-header__bg img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.page-header--with-photo .page-header__inner{
  position:relative;z-index:2;padding:60px 20px;
}
.page-header__eyebrow{
  color:var(--color-brand-deep);font-weight:700;
  letter-spacing:.18em;font-size:.72rem;margin-bottom:.6em;
}
.page-header__title{font-size:1.6rem;margin-bottom:.4em}
.page-header__desc{color:var(--color-text-mute);font-size:.95rem;max-width:680px;margin:0 auto}

/* ========== Forms ========== */
.form-row{margin-bottom:20px}
.form-row label{
  display:block;font-weight:600;font-size:.92rem;margin-bottom:.4em;
}
.form-row label .required{color:#D9534F;margin-left:.3em;font-size:.8rem}
.form-row input,
.form-row select,
.form-row textarea{
  width:100%;padding:12px 14px;border:1px solid var(--color-border);
  border-radius:8px;font-family:inherit;font-size:1rem;background:#fff;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{outline:0;border-color:var(--color-brand)}
.form-row textarea{min-height:140px;resize:vertical}
.form-note{font-size:.82rem;color:var(--color-text-mute);margin-top:.4em}

/* ========== CTA bar ========== */
.cta-bar{
  background:linear-gradient(135deg,var(--color-brand) 0%,var(--color-brand-deep) 100%);
  color:#fff;padding:48px 20px;text-align:center;
}
.cta-bar h2{color:#fff;font-size:1.4rem;margin-bottom:.4em}
.cta-bar p{color:rgba(255,255,255,.92);margin-bottom:1.4em}
.cta-bar .btn--primary{background:#fff;color:var(--color-brand-deep) !important}
.cta-bar .btn--primary:hover{background:#FFF6F9}
.cta-bar .btn--ghost{background:transparent;color:#fff !important;border-color:rgba(255,255,255,.5)}
.cta-bar .btn--ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.cta-bar__tel{
  display:inline-block;color:#fff;font-size:1.8rem;font-weight:700;
  letter-spacing:.05em;margin-top:.4em;
}
.cta-bar__tel small{font-size:.7rem;display:block;font-weight:400;opacity:.8;margin-bottom:.1em}

/* ========== Footer ========== */
.site-footer{
  background:#2A2A2A;color:#D9D9D9;padding:48px 20px 24px;
  font-size:.88rem;
}
.site-footer a{color:#D9D9D9}
.site-footer a:hover{color:#fff;text-decoration:underline}
.footer-grid{
  display:grid;gap:32px;grid-template-columns:1fr;
  max-width:var(--container);margin:0 auto 32px;
}
.footer-brand{display:flex;flex-direction:column;gap:10px}
.footer-brand img{width:60px;background:#fff;border-radius:8px;padding:6px}
.footer-brand strong{color:#fff;font-size:1rem}
.footer-brand p{margin:0;font-size:.85rem;color:#B8B8B8;line-height:1.7}
.footer-nav__title{color:#fff;font-size:.92rem;margin-bottom:.8em;font-weight:600}
.footer-nav ul{list-style:none;padding:0;margin:0}
.footer-nav li{margin-bottom:.4em}
.footer-bottom{
  max-width:var(--container);margin:0 auto;
  padding-top:20px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:10px;
  font-size:.8rem;color:#9A9A9A;
}

/* ========== Notice / Note box ========== */
.notice{
  background:var(--color-warning-bg);border:1px solid var(--color-warning-border);
  border-radius:var(--radius);padding:14px 18px;font-size:.88rem;color:#6B5018;
  margin-bottom:1.5em;
}
.notice strong{color:#5A3E0C}
.notice--success{
  background:#ECFDF5;border:1px solid #A7F3D0;
  border-radius:var(--radius);padding:14px 18px;font-size:.88rem;color:#065F46;
  margin-bottom:1.5em;
}
.notice--success strong{color:#047857}
.form-row--honeypot{
  position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden;
}

/* ========== Tablet & Desktop ========== */
@media (min-width:760px){
  .section{padding:80px 0}
  .section-title{font-size:1.85rem;margin-bottom:1.8em}
  .hero{padding:80px 20px 88px}
  .hero__title{font-size:2.4rem}
  .hero__desc{font-size:1.08rem}
  .grid--2{grid-template-columns:repeat(2,1fr)}
  .grid--3{grid-template-columns:repeat(3,1fr)}
  .grid--4{grid-template-columns:repeat(4,1fr)}
  .pillars{grid-template-columns:repeat(3,1fr)}
  .troubles{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(4,1fr)}
  .page-header{padding:56px 20px}
  .page-header__title{font-size:2rem}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .cta-bar h2{font-size:1.7rem}
}

@media (min-width:1080px){
  .site-header{--site-header-height:154px}
  .site-header__inner{padding:11px 20px}
  .site-logo img{height:132px;max-width:360px}
  .nav-toggle{display:none}
  .global-nav{display:block}
  .mobile-nav{display:none !important}
}

/* ========== Pillars (3本柱) ========== */
.pillars{display:grid;gap:20px;grid-template-columns:1fr}
.pillar{
  background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);
  padding:28px 24px;text-align:center;position:relative;overflow:hidden;
}
.pillar__num{
  font-family:var(--font-en);font-size:.78rem;letter-spacing:.18em;
  color:var(--color-brand-deep);font-weight:700;margin-bottom:.6em;
}
.pillar__icon{
  width:auto;min-width:56px;height:32px;border-radius:999px;margin:0 auto 14px;
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 12px;
  font-size:.82rem;font-weight:700;
}
.pillar--a .pillar__icon{background:var(--color-brand-soft);color:var(--color-brand-deep)}
.pillar--b .pillar__icon{background:var(--color-trust-light);color:var(--color-trust)}
.pillar--c .pillar__icon{background:#EFF7E8;color:var(--color-leaf-deep)}
.pillar h3{font-size:1.15rem;margin-bottom:.5em}
.pillar p{color:var(--color-text-mute);font-size:.92rem;margin:0}

/* ========== Stats ========== */
.stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;
  text-align:center;
}
.stat{
  background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);
  padding:20px 10px 18px;
}
.stat__num{
  font-family:var(--font-en);font-size:1.8rem;font-weight:700;
  color:var(--color-brand-deep);line-height:1.1;
}
.stat__num small{font-size:.85rem;font-weight:600;margin-left:.15em}
.stat__label{font-size:.78rem;color:var(--color-text-mute);margin-top:.2em}

/* ========== Trouble list (こんなお悩み) ========== */
.troubles{
  display:grid;gap:12px;grid-template-columns:1fr;
}
.trouble{
  background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);
  padding:18px 18px 18px 56px;position:relative;font-size:.95rem;line-height:1.6;
}
.trouble::before{
  content:"\201C";position:absolute;left:14px;top:8px;
  font-family:Georgia,serif;font-size:2.4rem;color:var(--color-brand);line-height:1;
}

/* ========== Top flow timeline ========== */
.steps li::before{
  content:attr(data-step-icon);
  font-family:var(--font-jp);
  font-size:.72rem;
  letter-spacing:0;
  width:42px;height:42px;
}

/* ========== Photo strip / Image band ========== */
.photo-band{
  display:grid;gap:8px;grid-template-columns:repeat(2,1fr);
  margin:0;padding:0;
}
.photo-band img{
  display:block;width:100%;aspect-ratio:1/1;object-fit:cover;
}

/* ========== Feature with photo (alternating image+text) ========== */
.feature-row{
  display:grid;gap:24px;align-items:center;
  grid-template-columns:1fr;margin-bottom:48px;
}
.feature-row__photo{
  border-radius:18px;overflow:hidden;
  box-shadow:0 10px 32px rgba(201,98,126,.14);
}
.feature-row__photo img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
.feature-row__body h3{
  font-size:1.3rem;color:var(--color-brand-deep);
  margin-bottom:.4em;
}
.feature-row__body p{color:var(--color-text);margin:0 0 1em}
.feature-row__eyebrow{
  font-family:var(--font-en);font-size:.78rem;letter-spacing:.18em;
  color:var(--color-brand-deep);font-weight:700;margin-bottom:.4em;
}

/* ========== Quote / Lead ========== */
.lead-quote{
  background:var(--color-brand-pale);
  border-left:4px solid var(--color-brand);
  padding:18px 24px;border-radius:8px;
  font-size:1.02rem;line-height:1.9;color:var(--color-text);
  margin:0 0 2em;
}

/* ========== Pillar visual refresh ========== */
.pillar{box-shadow:0 4px 16px rgba(201,98,126,.06)}
.pillar--a{background:linear-gradient(180deg,#fff 0%,var(--color-brand-pale) 100%)}
.pillar--b{background:linear-gradient(180deg,#fff 0%,var(--color-trust-light) 100%)}
.pillar--c{background:linear-gradient(180deg,#fff 0%,#F2F8EB 100%)}

/* ========== Section title softer ========== */
.section-title::after{
  background:linear-gradient(90deg,var(--color-brand) 0%,var(--color-leaf) 100%);
  width:60px;height:3px;
}

/* ========== Section with photo background ========== */
.section--photo{
  position:relative;overflow:hidden;
}
.section--photo .section__bg{
  position:absolute;inset:0;z-index:1;
}
.section--photo .section__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(251,246,241,.92) 0%,rgba(255,255,255,.95) 100%);
}
.section--photo .section__bg img{
  width:100%;height:100%;object-fit:cover;display:block;opacity:.6;
}
.section--photo .container{position:relative;z-index:2}

/* ========== Header: gentle ribbon ========== */
.site-header{
  background:rgba(255,253,251,.95);
  border-bottom:1px solid var(--color-brand-soft);
}

/* ========== CTA Bar refresh ========== */
.cta-bar{
  background:
    radial-gradient(circle at 20% 20%,rgba(255,255,255,.15) 0%,transparent 40%),
    linear-gradient(135deg,var(--color-brand) 0%,var(--color-brand-deep) 100%);
}

/* ========== Footer: soft top accent ========== */
.site-footer{position:relative}
.site-footer::before{
  content:"";display:block;height:4px;
  background:linear-gradient(90deg,var(--color-brand) 0%,var(--color-leaf) 50%,var(--color-brand) 100%);
  position:absolute;top:0;left:0;right:0;
}

/* ========== Tablet/desktop adjustments for new elements ========== */
@media (min-width:760px){
  .photo-band{grid-template-columns:repeat(4,1fr)}
  .feature-row{grid-template-columns:1fr 1fr;gap:48px;margin-bottom:64px}
  .feature-row--reverse .feature-row__photo{order:2}
  .feature-row__body h3{font-size:1.55rem}
  .hero--with-photo .hero__photo{margin-top:40px}
  .hero--visual{
    min-height:620px;
    padding:94px 20px 112px;
  }
  .hero--visual .hero__title{font-size:2.7rem}
  .proof-strip__grid{grid-template-columns:repeat(3,1fr)}
  .proof-card{grid-template-columns:1fr}
  .proof-card img{width:100%;height:auto;min-height:0;aspect-ratio:16/10}
  .proof-card div{padding:16px 18px 18px}
  .trouble-layout{grid-template-columns:.86fr 1.14fr;gap:34px}
  .steps{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:12px;
    position:relative;
  }
  .steps li{
    margin-bottom:0;
    padding:72px 16px 18px;
    min-height:230px;
  }
  .steps li::before{
    left:16px;top:18px;
  }
  .steps li::after{
    content:"";
    position:absolute;
    top:38px;
    left:62px;
    right:-16px;
    height:2px;
    background:linear-gradient(90deg,var(--color-brand-soft),var(--color-trust-light));
    z-index:0;
  }
  .steps li:last-child::after{display:none}
}

/* ========== Util ========== */
.text-center{text-align:center}
.mt-1{margin-top:1em}
.mt-2{margin-top:2em}
.mb-0{margin-bottom:0}
.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
