/* =========================================================
   メイトグループ 2案目デモ「ひだまりポップ路線」
   白 × パステル4法人カラー ／ 大きな角丸 ／ 昼の空と月
   Noto Sans JP（見出し・本文）＋ Quicksand（英字）
   ========================================================= */
:root{
  --paper:#FFFFFF;
  --sky:#EFF6FA;        /* 淡い空色バンド */
  --cream:#FFF7E8;      /* ひだまりクリームバンド */
  --mint:#EDF6EF;       /* 淡い若葉バンド */
  --ink:#3A4148;
  --ink-soft:#707983;
  --navy:#3D5680;       /* やわらげた紺 */
  --navy-deep:#2C405F;
  --moon:#F2C14E;       /* はちみつ色の月 */
  --moon-deep:#E0A93E;
  /* 各法人カラー（パステル明るめ） */
  --tax:#5FA572;    --tax-bg:#E3F2E7;
  --gyosei:#E89A4E; --gyosei-bg:#FCEEDC;
  --sharo:#E68FA6;  --sharo-bg:#FBE7ED;
  --kanri:#6D9BC8;  --kanri-bg:#E4EFF8;
  --line-green:#06C755;
  --radius:22px;
  --radius-lg:32px;
  --shadow:0 18px 40px -24px rgba(61,86,128,.28);
  --shadow-soft:0 10px 26px -18px rgba(61,86,128,.22);
  --max:1120px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --maru:"Noto Sans JP",sans-serif;
  --sans:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN",sans-serif;
  --en:"Quicksand","Noto Sans JP",sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  margin:0;overflow-x:clip;max-width:100%;
  font-family:var(--sans);color:var(--ink);
  background:var(--paper);
  line-height:1.95;letter-spacing:.03em;
  -webkit-font-smoothing:antialiased;
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--maru);font-weight:800;line-height:1.55;letter-spacing:.04em;color:var(--navy-deep)}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.center{text-align:center}
.nb{white-space:nowrap}
br.sp-only{display:none}
.sec-lead,.lead,.core p{word-break:keep-all;overflow-wrap:anywhere;line-break:strict}
.sec-title,.hero h1,.core h2,.purpose-card .big,.worry-punch .big{overflow-wrap:anywhere;line-break:strict}

/* demo note */
.demo-note{
  background:var(--navy-deep);color:#fff;text-align:center;
  font-size:.74rem;letter-spacing:.08em;padding:7px 12px;line-height:1.6;
}

/* ============ eyebrow / section head ============ */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--en);font-weight:700;font-size:.8rem;letter-spacing:.3em;
  color:var(--moon-deep);margin:0 0 14px;text-transform:uppercase;
}
.eyebrow::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--moon)}
.sec-title{font-size:clamp(1.55rem,3.6vw,2.2rem);margin:0 0 18px;font-weight:900}
.sec-lead{max-width:680px;margin:0 auto 14px;color:var(--ink-soft);font-size:1.02rem}

/* ゆる波線アンダーライン */
.u{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='44' height='9'%3E%3Cpath d='M0 6 Q5.5 1 11 6 T22 6 T33 6 T44 6' stroke='%23F2C14E' stroke-width='3' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:repeat-x;background-position:0 100%;background-size:44px 9px;
  padding-bottom:10px;
}
mark{
  background:linear-gradient(180deg,transparent 55%,var(--sharo-bg) 55%);
  color:var(--navy-deep);padding:0 .1em;border-radius:4px;font-weight:800;
}

/* ============ header ============ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(61,86,128,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:40px;height:40px}
.brand .logo-full{width:auto;height:40px;max-width:340px}
/* グループロゴは太い大文字ラテンで光学的に大きく見えるため、和文ロゴと見た目を揃える微調整（A案と同じ基準） */
.brand .logo-full[src*="logo-group"]{height:37px}
/* フッターはヘッダーより一回り小さく（A案と統一） */
.foot-brand .brand .logo-full{height:34px}
.foot-brand .brand .logo-full[src*="logo-group"]{height:31px}
.brand .name{font-family:var(--maru);font-weight:800;color:var(--navy-deep);font-size:1.02rem;line-height:1.25;display:flex;flex-direction:column}
.brand .name small{font-size:.68rem;font-weight:700;color:var(--ink-soft);letter-spacing:.12em}
.nav{display:flex;align-items:center;gap:2px}
.nav a{
  font-family:var(--maru);font-weight:700;font-size:.84rem;color:var(--ink);
  padding:9px 11px;border-radius:999px;transition:background .25s,color .25s;white-space:nowrap;
}
.nav a:hover{background:var(--sky);color:var(--navy)}
.nav .btn{margin-left:8px}
.nav a.btn-primary{color:#fff}
.nav a.btn-primary:hover{background:var(--navy-deep);color:#fff}
.lang-switch{display:inline-flex;align-items:center;gap:4px;margin-left:10px;font-family:var(--en);font-weight:600;font-size:.74rem;letter-spacing:.05em}
.lang-switch a{color:var(--ink-soft);text-decoration:none;padding:3px 6px;border-radius:6px;line-height:1}
.lang-switch a:hover{background:var(--sky);color:var(--navy)}
.lang-switch a.is-active{color:var(--navy-deep);background:var(--sky);pointer-events:none}
.lang-switch .sep{color:var(--ink-soft);opacity:.4}
/* EN-TOGGLE-HIDE: 英語版が一般公開になったら次の1行を削除して切替ボタンを復活 */
.lang-switch{display:none !important}
/* RECRUIT-HIDE: 採用ページが公開準備できたら次の1行（とこのコメント）を削除して採用導線を復活 */
.nav a[href="/recruit/"],.nav a[href="/recruit-tax/"],.foot-col a[href="/recruit/"],.foot-col a[href="/recruit-tax/"]{display:none !important}
.lang-mobile{display:none}
.nav-toggle{display:none;flex-shrink:0;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;border:0;background:none;cursor:pointer;padding:9px;z-index:70}
.nav-toggle span{display:block;height:2.6px;border-radius:3px;background:var(--navy);transition:transform .3s,opacity .3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7.6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7.6px) rotate(-45deg)}

/* ============ buttons ============ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--maru);font-weight:800;font-size:.95rem;letter-spacing:.06em;
  padding:14px 30px;border-radius:999px;transition:transform .25s,box-shadow .25s,background .25s,color .25s;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:var(--shadow-soft)}
.btn-primary:hover{background:var(--navy-deep);box-shadow:var(--shadow)}
.btn-line{background:var(--line-green);color:#fff;box-shadow:var(--shadow-soft)}
.btn-line:hover{filter:brightness(1.06)}
.btn-line .ic{width:20px;height:20px}
.btn-ghost{background:#fff;color:var(--navy);border:2px solid rgba(61,86,128,.25)}
.btn-ghost:hover{border-color:var(--navy);background:var(--sky)}

/* floating LINE */
.float-cta{
  position:fixed;right:18px;bottom:18px;z-index:80;
  display:inline-flex;align-items:center;gap:8px;
  background:var(--line-green);color:#fff;
  font-family:var(--maru);font-weight:800;font-size:.88rem;
  padding:13px 20px;border-radius:999px;box-shadow:0 14px 30px -12px rgba(6,199,85,.55);
  transition:transform .25s;
}
.float-cta:hover{transform:translateY(-2px) scale(1.03)}
.float-cta .ic{width:20px;height:20px}

/* to-top（JS注入想定なし・静的） */
.to-top{
  position:fixed;right:24px;bottom:84px;z-index:79;
  width:46px;height:46px;border-radius:50%;background:#fff;color:var(--navy);
  border:2px solid rgba(61,86,128,.18);display:grid;place-items:center;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.3s;cursor:pointer;
}
.to-top.show{opacity:1;visibility:visible;transform:none}
.to-top:hover{background:var(--sky)}

/* ============ バンド（大きな角丸パネル） ============ */
.band{
  max-width:1220px;margin:28px auto;padding:76px 24px;
  border-radius:var(--radius-lg);
}
.band-sky{background:var(--sky)}
.band-cream{background:var(--cream)}
.band-mint{background:var(--mint)}
/* さすてなメイト税理士法人サイトのみ：ベース黄色→淡い黄緑／アクセント金→緑（グループTOPは現状維持／2026-06-19） */
body.tax{--cream:#F1F7E8;--moon:#5FA572;--moon-deep:#4E8C42}
body.tax .core{background:linear-gradient(180deg,#E7F0F8 0%,#F1F7E8 100%)}
body.tax .tax-mascot{background:linear-gradient(180deg,#EBF3DC 0%,var(--cream) 100%)}
body.tax .shelf-wrap{--moon:#F2C14E;--moon-deep:#E0A93E}
body.tax .ticket,body.tax .vm-label,body.tax .faq-item summary::before{background:#3F7A33;color:#fff}
body.tax .band-navy .eyebrow,body.tax .t-card.future-card .num{color:#fff}
body.tax .band-navy .eyebrow::before{background:#9BC34A}
/* つむぎメイト社会保険労務士法人サイトのみ：ベース黄色→淡いピンク／アクセント金→ピンク（他サイトは現状維持／2026-06-19） */
body.sr-page{--cream:#FBE7ED;--moon:#E68FA6;--moon-deep:#B83E63}
body.sr-page .g,body.sr-page .core h2 .g{color:#D96C92}
body.sr-page .core{background:linear-gradient(180deg,#FCEFF4 0%,#FBE7ED 100%)}
body.sr-page .band-mint{background:#F6D5E1}
body.sr-page .info-table dt{color:#D96C92;background:#FBE7ED}
.band-plain{background:var(--paper);margin:48px auto;padding:40px 24px}
@media (max-width:1260px){.band{margin-left:16px;margin-right:16px}}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============ HERO ============ */
.hero{position:relative;overflow:hidden;
  background-color:#FFFBF0;
  background-image:
    radial-gradient(rgba(224,169,62,.12) 1.4px, transparent 1.5px),
    radial-gradient(130% 95% at 90% -12%, rgba(242,193,78,.22) 0%, rgba(242,193,78,0) 52%),
    radial-gradient(95% 90% at -10% 112%, rgba(95,165,114,.14) 0%, rgba(95,165,114,0) 52%);
  background-size:20px 20px, 100% 100%, 100% 100%;
}
.hero-grid{
  display:grid;grid-template-columns:1.06fr .94fr;gap:48px;align-items:center;
  padding-top:72px;padding-bottom:80px;
}
.hero .tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--cream);border:1.5px dashed var(--moon-deep);
  color:var(--navy-deep);font-family:var(--maru);font-weight:700;font-size:.82rem;
  padding:7px 18px;border-radius:999px;margin-bottom:22px;
}
.hero h1{
  font-size:clamp(2rem,4.8vw,3.2rem);font-weight:900;line-height:1.7;margin:0 0 22px;
}
.hero h1 .u{padding-bottom:4px;background-size:40px 7px}
.hero .lead{color:var(--ink-soft);font-size:1.05rem;margin:0 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  background:#fff;border:1.5px solid rgba(61,86,128,.14);border-radius:999px;
  font-family:var(--maru);font-weight:700;font-size:.8rem;color:var(--ink);
  padding:7px 14px;box-shadow:var(--shadow-soft);
}
.chip .dot{width:9px;height:9px;border-radius:50%;background:var(--tax);display:inline-block}

/* hero 背景のゆる丸 */
.hero::before,.hero::after{
  content:"";position:absolute;border-radius:50%;z-index:0;pointer-events:none;
}
.hero::before{width:480px;height:480px;right:-140px;top:-160px;background:radial-gradient(circle,rgba(242,193,78,.30),rgba(242,193,78,0) 70%)}
.hero::after{width:260px;height:260px;left:-110px;bottom:-90px;background:radial-gradient(circle,rgba(95,165,114,.22),rgba(95,165,114,0) 70%)}
.hero .wrap{position:relative;z-index:1}

/* 月の満ち欠けアート（グループTOPヒーロー・2026-06-11改） */
.moon-rise{text-align:center}
.mr-art{display:block;width:100%;max-width:470px;height:auto;margin:0 auto}
.mr-caption{
  margin:4px auto 0;width:fit-content;max-width:100%;
  background:var(--cream);border-radius:999px;padding:11px 28px;
  font-family:var(--maru);font-weight:900;font-size:1.06rem;color:var(--navy-deep);
  line-height:1.7;
}
.mr-sub{margin:12px 0 0;font-size:.84rem;color:var(--ink-soft)}
/* ヒーロー右：事務所写真 */
.hero-photo{margin:0;position:relative;border-radius:26px;overflow:hidden;box-shadow:0 26px 60px rgba(44,64,95,.30)}
.hero-photo img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover}
.hero-photo figcaption{position:absolute;left:13px;bottom:13px;background:rgba(44,64,95,.72);color:#fff;font-family:var(--en),var(--maru);font-weight:600;font-size:.62rem;letter-spacing:.06em;padding:4px 11px;border-radius:999px}
/* OUR STORY セクションの月の図（横型タイムライン） */
.story-art{margin:34px auto 0;max-width:640px}
/* 月の物語ジャーニー（創業→相続） */
.story-art:has(.journey){max-width:820px}
.journey{max-width:820px;margin:0 auto}
.journey-curve{display:block;width:100%;height:auto;overflow:visible}
.journey-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:2px}
.js{text-align:center;padding:0 3px}
.js .ic{width:30px;height:30px;display:block;margin:0 auto 9px}
.js b{display:block;font-family:var(--maru);font-weight:800;font-size:1.04rem;color:var(--navy-deep);letter-spacing:.08em;margin-bottom:8px}
.js p{margin:0;font-size:.74rem;line-height:1.8;color:var(--ink-soft)}
.journey-foot{text-align:center;margin-top:30px}
.journey-foot span{display:block;font-size:.8rem;color:var(--ink-soft)}
.journey-foot b{display:flex;align-items:center;justify-content:center;gap:14px;font-family:var(--maru);font-weight:800;font-size:1rem;color:var(--navy-deep);margin-top:10px;white-space:nowrap}
.journey-foot .ln{flex:none;width:35px;height:1.5px;background:#C9A961;border-radius:1px}
@media(max-width:720px){
  .journey-drops{display:none}
  .journey-steps{grid-template-columns:1fr;gap:0;max-width:360px;margin:0 auto}
  .js{display:grid;grid-template-columns:36px 1fr;column-gap:14px;text-align:left;align-items:center;padding:15px 4px;border-bottom:1px dashed #E7DCC9}
  .js .ic{margin:0;grid-row:span 2;align-self:center}
  .js b{margin-bottom:3px}
  .js p br.sp-only{display:inline}
}
@media(max-width:640px){
  .journey-foot span{font-size:.75rem}
  .journey-foot b{font-size:.9rem;gap:4px}
  .journey-foot .ln{width:14px}
}

/* 昼の空パネル（グループTOP・旧版） */
.sky-panel{
  position:relative;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,#DDEEF8 0%,#EFF7FB 55%,#FFF7E8 100%);
  padding:46px 36px 38px;box-shadow:var(--shadow);overflow:hidden;
}
.sky-panel .cloud{
  position:absolute;background:#fff;border-radius:999px;opacity:.9;
}
.sky-panel .cloud::before,.sky-panel .cloud::after{content:"";position:absolute;background:#fff;border-radius:50%}
.sky-panel .c1{width:86px;height:26px;left:22px;top:34px}
.sky-panel .c1::before{width:34px;height:34px;left:14px;top:-16px}
.sky-panel .c1::after{width:24px;height:24px;left:44px;top:-10px}
.sky-panel .c2{width:64px;height:20px;right:26px;top:64px;opacity:.7}
.sky-panel .c2::before{width:26px;height:26px;left:10px;top:-12px}
.sky-panel .c2::after{width:18px;height:18px;left:34px;top:-8px}
.sp-moon{
  width:92px;height:92px;margin:0 auto 6px;border-radius:50%;
  background:radial-gradient(circle at 36% 32%,#FBDF9A 0%,var(--moon) 60%,var(--moon-deep) 100%);
  box-shadow:0 0 0 12px rgba(242,193,78,.18),0 0 0 26px rgba(242,193,78,.08);
  position:relative;z-index:1;
}
.sp-title{font-family:var(--maru);font-weight:900;font-size:1.3rem;color:var(--navy-deep);text-align:center;margin:14px 0 4px;line-height:1.6;position:relative;z-index:1}
.sp-sub{text-align:center;color:var(--ink-soft);font-size:.88rem;margin:0 0 24px;position:relative;z-index:1}
.moon-journey{
  display:flex;justify-content:space-between;align-items:flex-start;gap:6px;
  position:relative;z-index:1;padding:0 6px;
}
.moon-journey::before{
  content:"";position:absolute;left:8%;right:8%;top:19px;height:0;
  border-top:2.5px dotted rgba(61,86,128,.3);
}
.mj{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;font-family:var(--maru);font-weight:800;font-size:.82rem;color:var(--navy-deep)}
.mj .m{
  width:40px;height:40px;border-radius:50%;background:#fff;
  border:2.5px solid var(--moon-deep);position:relative;overflow:hidden;
  box-shadow:var(--shadow-soft);
}
.mj .m::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--moon)}
.mj .m1::after{clip-path:inset(0 72% 0 0)}
.mj .m2::after{clip-path:inset(0 50% 0 0)}
.mj .m3::after{clip-path:inset(0 28% 0 0)}
.mj .m4::after{clip-path:inset(0 10% 0 0)}
.mj .m5::after{clip-path:none}
.sp-foot{
  margin:24px auto 0;text-align:center;position:relative;z-index:1;
  font-family:var(--maru);font-weight:700;font-size:.92rem;color:var(--navy-deep);
  background:#fff;border-radius:999px;padding:8px 22px;width:fit-content;box-shadow:var(--shadow-soft);
}
.sp-foot b{color:var(--moon-deep)}

/* マスコットパネル（税理士TOP） */
.tax-mascot{
  position:relative;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,#FFF3D9 0%,var(--cream) 100%);
  padding:52px 36px 30px;box-shadow:var(--shadow);text-align:center;overflow:hidden;
}
.tax-mascot img{margin:0 auto;width:min(64%,250px);position:relative;z-index:1}
.tax-mascot .speech{
  position:absolute;top:28px;left:50%;transform:translateX(-50%) rotate(-2deg);
  background:#fff;border:2px solid var(--moon-deep);border-radius:999px;
  font-family:var(--maru);font-weight:800;font-size:.9rem;line-height:1.35;color:var(--navy-deep);
  padding:6px 20px;z-index:2;box-shadow:var(--shadow-soft);white-space:nowrap;
}
.tax-mascot .speech::after{
  content:"";position:absolute;left:50%;bottom:-9px;transform:translateX(-50%) rotate(45deg);
  width:14px;height:14px;background:#fff;border-right:2px solid var(--moon-deep);border-bottom:2px solid var(--moon-deep);
}
.tax-mascot .ph-note{margin:14px 0 0;font-size:.76rem;color:var(--ink-soft);position:relative;z-index:1}
.tax-mascot::before{
  content:"";position:absolute;width:200px;height:200px;border-radius:50%;
  right:-70px;bottom:-70px;background:rgba(242,193,78,.25);
}

/* ============ グループ構成（おてて繋ぎカード） ============ */
.family{position:relative;margin-top:46px}
.family-center{
  width:268px;margin:0 auto 18px;background:#fff;border-radius:28px;
  box-shadow:var(--shadow);padding:26px 20px 20px;position:relative;z-index:2;
}
.family-center img{width:64px;height:64px;margin:0 auto 8px}
.family-center .logo-full{width:auto;height:auto;max-width:215px;margin:0 auto 4px;display:block}
.family-center .en{display:block;font-family:var(--en);font-weight:700;font-size:.7rem;letter-spacing:.26em;color:var(--moon-deep)}
.family-center strong{display:block;font-family:var(--maru);font-weight:900;font-size:1.06rem;color:var(--navy-deep)}
.family-center small{display:block;font-size:.7rem;color:var(--ink-soft);margin-top:6px;line-height:1.6}
.family-link{
  width:0;height:34px;margin:0 auto;border-left:2.5px dotted rgba(61,86,128,.35);
}
.family-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:left}
.firm{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:26px 22px 22px;position:relative;border-top:7px solid var(--tax);
  transition:transform .3s,box-shadow .3s;display:block;
}
a.firm:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.firm .badge{
  display:inline-block;border-radius:999px;padding:4px 16px;
  background:var(--tax-bg);color:var(--tax);margin-bottom:12px;
  font-family:var(--maru);font-weight:800;font-size:.78rem;letter-spacing:.06em;
}
.firm h3{font-size:1.02rem;margin:0 0 10px;line-height:1.6}
.firm ul{margin:0;padding:0;list-style:none;font-size:.84rem;color:var(--ink-soft)}
.firm ul li{padding-left:1.1em;position:relative}
.firm ul li::before{content:"";position:absolute;left:0;top:.78em;width:7px;height:7px;border-radius:50%;background:var(--tax-bg);border:1.5px solid var(--tax)}
.firm.kanri{border-top-color:#3D5680}
.firm.kanri .badge{background:#E6EBF4;color:#3D5680}
.firm.kanri ul li::before{background:#E6EBF4;border-color:#3D5680}
.firm.gyosei{border-top-color:var(--gyosei)}
.firm.gyosei .badge{background:var(--gyosei-bg);color:var(--gyosei)}
.firm.gyosei ul li::before{background:var(--gyosei-bg);border-color:var(--gyosei)}
.firm.sharo{border-top-color:var(--sharo)}
.firm.sharo .badge{background:var(--sharo-bg);color:var(--sharo)}
.firm.sharo ul li::before{background:var(--sharo-bg);border-color:var(--sharo)}
.firm .more{display:inline-block;margin-top:12px;font-family:var(--maru);font-weight:800;font-size:.82rem;color:var(--tax)}
.firm.is-soon{opacity:.78}
.firm-soon{
  position:absolute;top:-12px;right:14px;
  background:var(--navy);color:#fff;font-family:var(--maru);font-weight:800;
  font-size:.7rem;letter-spacing:.1em;padding:4px 13px;border-radius:999px;
}
.soon-note{margin:10px 0 0;font-size:.74rem;color:var(--ink-soft)}

/* ============ Purpose ============ */
.purpose-card{
  background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);
  padding:46px 34px 40px;margin-top:36px;position:relative;
}
.ticket{
  display:inline-block;background:var(--moon);color:var(--navy-deep);
  font-family:var(--maru);font-weight:900;font-size:.92rem;letter-spacing:.08em;
  padding:9px 26px;border-radius:999px;margin-bottom:20px;
  position:relative;
}
.ticket::before,.ticket::after{
  content:"";position:absolute;top:50%;width:12px;height:12px;border-radius:50%;
  background:#fff;transform:translateY(-50%);
}
.ticket::before{left:-6px}
.ticket::after{right:-6px}
.purpose-card .big{
  font-family:var(--maru);font-weight:900;font-size:clamp(1.2rem,2.8vw,1.6rem);
  color:var(--navy-deep);line-height:1.9;margin:0 0 8px;
}
.purpose-card .big em{font-style:normal;color:var(--moon-deep)}
.purpose-points{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:28px;
}
.pp{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  width:128px;padding:20px 10px 16px;border-radius:var(--radius);
  background:var(--sky);
  font-family:var(--maru);font-weight:800;font-size:.84rem;line-height:1.5;color:var(--navy-deep);
  text-align:center;
}
.pp:nth-child(2){background:var(--mint)}
.pp:nth-child(3){background:var(--cream)}
.pp:nth-child(4){background:var(--sharo-bg)}
.pp:nth-child(5){background:var(--gyosei-bg)}
.pp .ic{width:42px;height:42px}

/* ============ Worry（LINE風） ============ */
.worry{max-width:760px;margin:34px auto 0}
.worry-bubbles{display:flex;flex-direction:column;gap:13px;align-items:flex-start}
.bubble{
  position:relative;background:#fff;border-radius:18px 18px 18px 6px;
  box-shadow:var(--shadow-soft);
  font-family:var(--maru);font-weight:700;font-size:.95rem;color:var(--ink);
  padding:13px 22px;margin-left:54px;
  word-break:keep-all;overflow-wrap:anywhere;line-break:strict;
}
.bubble::before{
  content:"";position:absolute;left:-46px;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  background:var(--kanri-bg) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 36 36'%3E%3Ccircle cx='18' cy='14' r='6' fill='%236D9BC8'/%3E%3Cpath d='M6 32c0-7 5.4-11 12-11s12 4 12 11' fill='%236D9BC8'/%3E%3C/svg%3E") center/cover;
}
.worry-bubbles .bubble:nth-child(2){align-self:flex-end;border-radius:18px 18px 6px 18px;margin-left:0;margin-right:54px}
.worry-bubbles .bubble:nth-child(2)::before{left:auto;right:-46px;background-color:var(--sharo-bg)}
.worry-bubbles .bubble:nth-child(4){align-self:flex-end;border-radius:18px 18px 6px 18px;margin-left:0;margin-right:54px}
.worry-bubbles .bubble:nth-child(4)::before{left:auto;right:-46px;background-color:var(--gyosei-bg)}
.worry-punch{
  margin-top:32px;background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow);padding:36px 28px;text-align:center;
}
.worry-punch .q{margin:0 0 10px;color:var(--ink-soft);font-size:.95rem}
.worry-punch .big{
  margin:0;font-family:var(--maru);font-weight:900;
  font-size:clamp(1.25rem,3vw,1.7rem);color:var(--navy-deep);line-height:1.85;
}

/* ============ News ============ */
.news-list{max-width:760px;margin:30px auto 0;display:flex;flex-direction:column;gap:12px;text-align:left}
.news-item{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:16px 22px;transition:transform .25s,box-shadow .25s;
}
.news-item:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.news-date{font-family:var(--en);font-weight:700;font-size:.84rem;color:var(--ink-soft)}
.news-cat{
  font-family:var(--maru);font-weight:800;font-size:.72rem;color:var(--navy-deep);
  background:#E7ECF3;border-radius:999px;padding:3px 12px;
  width:104px;text-align:center;flex-shrink:0;
}
html[lang="en"] .news-cat{width:148px}
/* お知らせ：各社カラーで色分け（左帯＋カテゴリバッジ） */
.news-item{border-left:5px solid var(--navy)}
.news-item.is-group{border-left-color:var(--navy)}
.news-item.is-group .news-cat{color:var(--navy-deep);background:#E7ECF3}
.news-item.is-tax{border-left-color:var(--tax)}
.news-item.is-tax .news-cat{color:var(--tax);background:var(--tax-bg)}
.news-item.is-sharo{border-left-color:var(--sharo)}
.news-item.is-sharo .news-cat{color:var(--sharo);background:var(--sharo-bg)}
.news-item.is-gyosei{border-left-color:var(--gyosei)}
.news-item.is-gyosei .news-cat{color:var(--gyosei);background:var(--gyosei-bg)}
.news-title{font-size:.94rem;font-weight:500;flex:1;min-width:200px}

/* ============ Core CTA ============ */
.core{
  position:relative;text-align:center;border-radius:var(--radius-lg);
  background:linear-gradient(180deg,#DDEEF8 0%,#FFF7E8 100%);
  padding:72px 28px;box-shadow:var(--shadow);overflow:hidden;
}
.core .moon{width:68px;height:68px;margin:0 auto 16px}
.core h2{font-size:clamp(1.5rem,3.6vw,2.1rem);font-weight:900;margin:0 0 16px;line-height:1.7}
.core h2 .g{color:var(--moon-deep)}
.core p{color:var(--ink-soft);margin:0 auto 30px;max-width:600px}
.core .hero-cta{justify-content:center}
.core::before,.core::after{content:"";position:absolute;border-radius:50%;opacity:.5;pointer-events:none}
.core::before{width:220px;height:220px;left:-80px;top:-60px;background:#fff}
.core::after{width:170px;height:170px;right:-60px;bottom:-50px;background:#fff}

/* ============ Service cards（税理士TOP） ============ */
.svc-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;margin-top:38px;text-align:left;
}
.svc-card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:28px 24px 24px;transition:transform .3s,box-shadow .3s;text-align:center;
}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.svc-card .ic{width:54px;height:54px;margin:0 auto 14px;background:var(--sky);border-radius:16px;padding:7px}
.svc-card:nth-child(2n) .ic{background:var(--cream)}
.svc-card:nth-child(3n) .ic{background:var(--mint)}
.svc-card h3{font-size:1.05rem;margin:0 0 8px}
.svc-card p{margin:0;font-size:.86rem;color:var(--ink-soft);text-wrap:balance}

/* つむぎメイト社労士 TOP（社労士＝パステルピンク） */
.sr-page .svc-card .ic,.sr-page .svc-card:nth-child(2n) .ic,.sr-page .svc-card:nth-child(3n) .ic{background:var(--sharo-bg)}
.svc-grid.feat-grid{grid-template-columns:repeat(3,minmax(0,1fr));max-width:840px;margin-left:auto;margin-right:auto}
@media(max-width:720px){.svc-grid.feat-grid{grid-template-columns:1fr 1fr;max-width:520px}}
@media(max-width:480px){.svc-grid.feat-grid{grid-template-columns:1fr;max-width:340px}}
.sr-hero-art{display:flex;align-items:center;justify-content:center}
.sr-hero-art svg{width:min(100%,360px);height:auto}
.sr-note{margin:14px 0 0;text-align:center;font-size:.76rem;color:var(--ink-soft)}
.sr-list{list-style:none;margin:12px 0 0;padding:0;text-align:left}
.sr-list li{position:relative;padding:5px 0 5px 18px;color:var(--ink-soft);font-size:.88rem;line-height:1.7}
.sr-list li::before{content:"";position:absolute;left:1px;top:12px;width:7px;height:7px;border-radius:50%;background:var(--sharo)}
.sr-target{margin:14px 0 0;padding-top:12px;border-top:1px dashed rgba(230,143,166,.5);font-size:.84rem;color:var(--navy-deep);font-weight:700;line-height:1.6;text-align:left}
.svc-card p.sr-target{text-wrap:wrap}
.sr-target span{display:inline-block;margin-right:8px;padding:2px 11px;border-radius:999px;background:var(--sharo-bg);color:var(--sharo);font-size:.72rem;font-weight:800}

.assure-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.assure{
  background:#fff;border:2px dashed var(--moon-deep);border-radius:var(--radius);
  padding:20px 16px;text-align:center;
}
.assure b{display:block;font-family:var(--maru);font-weight:900;font-size:.98rem;color:var(--navy-deep);line-height:1.6}
.assure small{display:block;color:var(--ink-soft);font-size:.78rem;margin-top:6px}

/* ============ Strengths（税理士TOP） ============ */
.strength-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px;text-align:left}
.strength-card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:30px 26px;display:block;position:relative;
  transition:transform .3s,box-shadow .3s;
}
.strength-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.s-num{
  display:inline-block;font-family:var(--en);font-weight:700;font-size:.72rem;letter-spacing:.22em;
  color:var(--tax);background:var(--tax-bg);border-radius:999px;padding:4px 14px;margin-bottom:14px;
}
.strength-card:nth-child(2) .s-num{color:var(--kanri);background:var(--kanri-bg)}
.strength-card:nth-child(3) .s-num{color:var(--gyosei);background:var(--gyosei-bg)}
.strength-card h3{font-size:1.08rem;margin:0 0 10px;line-height:1.65}
.strength-card p{margin:0;font-size:.87rem;color:var(--ink-soft)}
.s-more{display:inline-block;margin-top:14px;font-family:var(--maru);font-weight:800;font-size:.84rem;color:var(--navy)}
.strength-card:hover .s-more{color:var(--moon-deep)}
/* 3つの強み フル内容版（個別ページを統合） */
.strength-list{max-width:1000px;margin:38px auto 0;text-align:left;display:flex;flex-direction:column;gap:20px}
.sf{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:30px 30px 26px}
.sf-head{border-bottom:1px solid #F0E6D6;padding-bottom:18px;margin-bottom:20px}
.sf-num{display:inline-block;font-family:var(--en);font-weight:700;font-size:.72rem;letter-spacing:.18em;color:var(--moon-deep);background:var(--cream);border-radius:999px;padding:4px 14px;margin-bottom:13px}
.sf-head h3{font-family:var(--maru);font-size:1.24rem;font-weight:800;color:var(--navy-deep);margin:0 0 10px;line-height:1.5}
.sf-lead{margin:0;font-size:.9rem;color:var(--ink-soft);line-height:1.8}
.sf-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.sf-pn{display:block;font-family:var(--en);font-size:.66rem;letter-spacing:.12em;font-weight:700;color:var(--moon-deep);margin-bottom:6px}
.sf-point h4{font-family:var(--maru);color:var(--navy-deep);font-size:.96rem;font-weight:800;margin:0 0 7px;line-height:1.5}
.sf-point p{margin:0;color:var(--ink-soft);font-size:.85rem;line-height:1.8;text-align:justify}
.sf-results{margin-top:22px;background:var(--cream);border-radius:14px;padding:18px 20px}
.sf-rt{display:block;font-family:var(--maru);font-size:.8rem;font-weight:800;color:var(--navy-deep);margin-bottom:11px}
.sf-rlist{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:16px 26px;text-align:left}
.sf-rlist li{color:var(--ink);display:flex;align-items:center;gap:10px;flex-wrap:nowrap}
.sf-rlist li b{flex-shrink:0;font-size:.72rem;background:#fff;color:var(--moon-deep);border-radius:999px;padding:3px 12px;font-weight:700;white-space:nowrap}
.sf-rlist li .sf-rsrc{flex:none;font-size:.85rem;color:var(--ink-soft);line-height:1.4}
.sf-rlist li em{flex-shrink:0;font-style:normal;font-weight:800;font-size:1.02rem;color:var(--navy-deep);white-space:nowrap}
/* 英語版：ラベル・融資元・金額が長く2列では重なるため、1列＋ラベル列固定幅＋金額右寄せで整列 */
html[lang="en"] .sf-rlist{grid-template-columns:1fr;gap:12px}
html[lang="en"] .sf-rlist li{flex-wrap:wrap}
html[lang="en"] .sf-rlist li b{width:160px;min-width:160px;text-align:center}
html[lang="en"] .sf-rlist li em{margin-left:auto}
@media(max-width:760px){.sf-points{grid-template-columns:1fr;gap:18px}.sf{padding:24px 20px}
  .sf-rlist{grid-template-columns:1fr;gap:16px}
  .sf-rlist li{display:flex;flex-direction:column;align-items:flex-start}
  .sf-rlist li .sf-rsrc{margin-top:7px;font-size:.82rem}
  .sf-rlist li em{margin-top:2px;font-size:1.06rem;justify-self:start;align-self:flex-start}
}
/* 代表挨拶 */
.ceo-msg{max-width:760px;margin:34px auto 0;text-align:left}
.ceo-msg p{color:var(--ink);font-size:.96rem;line-height:2.05;margin-bottom:18px}
.ceo-msg p:last-child{margin-bottom:0}
.ceo-sign{margin-top:30px;text-align:right;color:var(--ink-soft);font-size:.9rem;line-height:1.95}
.ceo-sign b{display:inline-block;margin-top:4px;font-family:var(--maru);color:var(--navy-deep);font-size:1.02rem}
@media(max-width:760px){.ceo-msg p{font-size:.92rem;line-height:1.95}.ceo-sign{text-align:left}}

/* ============ Mind band（やわらか紺） ============ */
.band-navy{background:var(--navy);color:#fff}
.band-navy .sec-title,.band-navy h2{color:#fff}
.band-navy .sec-lead{color:rgba(255,255,255,.82)}
.band-navy .eyebrow{color:var(--moon)}
.band-navy .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.band-navy .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}

/* ============ Staff ============ */
.staff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:880px;margin:38px auto 0;text-align:left}
.staff-card{
  display:flex;gap:20px;align-items:center;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:26px 24px;transition:transform .3s,box-shadow .3s;
}
.staff-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.staff-photo{
  flex-shrink:0;width:96px;height:96px;border-radius:50%;
  background:var(--sky);border:3px solid #fff;box-shadow:var(--shadow-soft);
  display:grid;place-items:center;font-size:.76rem;color:var(--ink-soft);text-align:center;line-height:1.5;
}
.staff-card .role{display:block;font-size:.74rem;color:var(--moon-deep);font-weight:700;margin-bottom:2px}
.staff-card h3{margin:0 0 6px;font-size:1.2rem}
.staff-card p{margin:0;font-size:.85rem;color:var(--ink-soft)}
.staff-card.is-static{cursor:default}
.staff-card.is-static:hover{transform:none;box-shadow:var(--shadow-soft)}

/* 役職の段組み見出し（代表／税理士） */
.tier-label{display:flex;align-items:center;justify-content:center;gap:16px;max-width:1040px;margin:54px auto 6px;font-size:1.2rem;font-weight:900;color:var(--ink)}
.tier-label:first-of-type{margin-top:4px}
.tier-label::before,.tier-label::after{content:"";height:1px;flex:1;max-width:130px;background:linear-gradient(90deg,transparent,#E6D5B2,transparent)}
.tier-label .en{font-family:var(--en);font-weight:600;font-size:.66rem;letter-spacing:.22em;color:var(--moon-deep);text-transform:uppercase}

/* 代表プロフィールの詳細を開閉（経歴・資格／得意分野／メディア） */
.profile-more{margin-top:16px;border-top:1px solid #EFE6D2}
.profile-more>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:9px;font-size:.9rem;font-weight:700;color:var(--moon-deep);padding:12px 0 2px}
.profile-more>summary::-webkit-details-marker{display:none}
.profile-more>summary::after{content:"";width:8px;height:8px;border-right:2.5px solid currentColor;border-bottom:2.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .2s}
.profile-more[open]>summary::after{transform:rotate(-135deg) translateY(1px)}
.profile-more>summary .lbl-open{display:none}
.profile-more[open]>summary .lbl-closed{display:none}
.profile-more[open]>summary .lbl-open{display:inline}
.profile-more>h3:first-of-type{margin-top:12px}

/* ============ Price ============ */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:38px;text-align:left}
.price-card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:30px 26px;color:var(--ink);
}
.price-card h3{margin:0 0 12px;font-size:1.1rem;display:flex;align-items:center;gap:8px}
.price-card h3::before{content:"";width:11px;height:11px;border-radius:50%;background:var(--moon)}
.price-card .p-val{
  font-family:var(--maru);color:var(--navy-deep);margin:0 0 12px;
  border-bottom:2.5px dotted rgba(61,86,128,.25);padding-bottom:12px;
  min-height:64px;box-sizing:border-box;
}
.price-card .p-val b{font-size:1.6rem;font-weight:900;letter-spacing:-.01em}
.price-card .p-val small{font-size:.82rem;color:var(--ink-soft);font-weight:700}
.price-card .p-val.is-formula{white-space:nowrap}
.price-card .p-val.is-formula b{font-size:1.45rem}
.price-card p{font-size:.86rem;color:var(--ink-soft);margin:0 0 10px}
.price-card .pdesc-d{letter-spacing:-.015em}/* PC専用の微字詰め（す。1行化・も、を2行目末に）。スマホは下の760pxで解除 */
.price-card .p-note{
  font-size:.76rem;background:var(--sky);border-radius:12px;padding:10px 14px;margin:12px 0 0;
}
.future{font-size:.8rem;color:var(--ink-soft)}

/* ============ FAQ ============ */
.faq-list{max-width:760px;margin:34px auto 0;display:flex;flex-direction:column;gap:12px;text-align:left}
.faq-item{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  padding:0;overflow:hidden;
}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;gap:14px;
  font-family:var(--maru);font-weight:800;font-size:.96rem;color:var(--navy-deep);
  padding:18px 22px;transition:background .25s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{
  content:"Q";flex-shrink:0;width:32px;height:32px;border-radius:50%;
  background:var(--moon);color:var(--navy-deep);font-family:var(--en);font-weight:700;
  display:grid;place-items:center;font-size:.9rem;
}
.faq-item summary::after{
  content:"+";margin-left:auto;font-family:var(--en);font-weight:700;font-size:1.3rem;color:var(--navy);
  transition:transform .3s;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{background:var(--sky)}
.faq-item .a{
  margin:0;padding:4px 22px 20px 68px;font-size:.9rem;color:var(--ink-soft);
}

/* ============ 下層ページ（強み詳細） ============ */
.page-hero{position:relative;overflow:hidden;background:var(--paper);text-align:center;padding:64px 0 56px}
.page-hero::before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;right:-150px;top:-170px;background:var(--sky)}
.page-hero::after{content:"";position:absolute;width:220px;height:220px;border-radius:50%;left:-100px;bottom:-110px;background:var(--cream)}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(1.7rem,4.2vw,2.5rem);font-weight:900;margin:6px 0 14px;line-height:1.55}
.crumbs{font-size:.78rem;color:var(--ink-soft);margin:0 0 18px}
.crumbs a{color:var(--navy);font-weight:700}
.crumbs a:hover{color:var(--moon-deep)}
.crumbs span{margin:0 8px;opacity:.5}
.lead-center{max-width:640px;margin:0 auto;color:var(--ink-soft);font-size:1rem}

.vm-block{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);
  max-width:780px;margin:0 auto;padding:42px 38px 36px;text-align:center;
}
.vm-label{
  display:inline-block;font-family:var(--en);font-weight:700;font-size:.74rem;letter-spacing:.24em;
  color:var(--navy-deep);background:var(--moon);border-radius:999px;padding:5px 18px;margin-bottom:18px;
}
.vm-statement{
  font-family:var(--maru);font-weight:900;font-size:clamp(1.25rem,2.8vw,1.6rem);
  color:var(--navy-deep);line-height:1.8;margin:0 0 16px;overflow-wrap:anywhere;line-break:strict;
}
.vm-statement .g{color:var(--moon-deep)}
.vm-block>p:not(.vm-statement){margin:0;color:var(--ink-soft);font-size:.95rem;text-align:left;word-break:normal;overflow-wrap:anywhere;line-break:strict}

.info-table{max-width:640px;margin:0 auto;text-align:left}
.info-table .row{
  display:flex;align-items:flex-start;gap:14px;
  padding:13px 4px;border-bottom:1.5px dashed rgba(61,86,128,.2);
}
.info-table .row:last-child{border-bottom:0}
.info-table dt{
  flex-shrink:0;min-width:96px;text-align:center;
  font-family:var(--maru);font-weight:800;font-size:.74rem;color:var(--tax);
  background:var(--tax-bg);border-radius:999px;padding:3px 12px;margin-top:2px;
}
.info-table dd{margin:0;font-size:.92rem;color:var(--ink)}
.info-table dd b{color:var(--moon-deep);font-family:var(--maru);font-weight:900}
/* 英語版：ラベルが長短バラつくため列幅を固定し、内容(dd)の開始位置を揃える */
html[lang="en"] .info-table dt{width:136px;min-width:136px}

@media (max-width:760px){
  .page-hero{padding:44px 0 40px}
  .vm-block{padding:32px 22px 28px}
  .info-table .row{flex-direction:column;gap:8px;align-items:flex-start}
}

/* ============ Footer ============ */
.site-footer{
  background:var(--sky);border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  margin-top:56px;padding:64px 0 28px;
}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px}
.foot-brand p{font-size:.86rem;color:var(--ink-soft);margin:14px 0 0}
.foot-col h4{font-size:.92rem;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.foot-col h4::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--moon)}
.foot-col a{display:block;font-size:.86rem;color:var(--ink-soft);padding:4px 0;transition:color .25s}
.foot-col a:hover{color:var(--navy)}
.parent-link a{font-family:var(--maru);font-weight:700;color:var(--navy)}
.foot-bottom{
  border-top:1.5px dashed rgba(61,86,128,.25);padding-top:22px;
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  font-size:.76rem;color:var(--ink-soft);
}

/* ============ Responsive ============ */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:36px;padding-top:48px;padding-bottom:56px}
  .family-grid{grid-template-columns:1fr 1fr}
  .strength-grid,.assure-grid,.price-grid{grid-template-columns:1fr}
  .staff-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px}
  .band{padding:56px 20px}
}
/* 英語ページはナビ項目が長いため、約1080px以下でハンバーガーメニューに切替（日本語版は下の760pxのまま） */
@media (max-width:1080px){
  html[lang="en"] .nav-toggle{display:flex}
  html[lang="en"] .lang-desktop{display:none}
  html[lang="en"] .lang-mobile{display:inline-flex;margin-left:auto;margin-right:6px}
  html[lang="en"] .nav{
    position:fixed;inset:0;z-index:65;
    flex-direction:column;justify-content:center;align-items:center;gap:18px;
    background:rgba(255,255,255,.985);
    transform:translateX(100%);transition:transform .35s var(--ease);
  }
  html[lang="en"] .nav.open{transform:none}
  html[lang="en"] .site-header.nav-active{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  html[lang="en"] .site-header.nav-active~.float-cta{opacity:0;pointer-events:none}
  html[lang="en"] .nav a{font-size:1.1rem;padding:10px 22px}
  html[lang="en"] .nav .btn{margin-left:0}
}
@media (max-width:760px){
  .nav-toggle{display:flex}
  .brand{min-width:0}
  .brand .logo-full,.brand .logo-full[src*="logo-group"]{max-height:32px;max-width:100%;height:auto}
  .lang-desktop{display:none}
  .lang-mobile{display:inline-flex;margin-left:auto;margin-right:6px}
  .nav{
    position:fixed;inset:0;z-index:65;
    flex-direction:column;justify-content:center;align-items:center;gap:18px;
    background:rgba(255,255,255,.97);
    transform:translateX(100%);transition:transform .35s var(--ease);
  }
  .nav.open{transform:none}
  /* backdrop-filter が fixed 子孫の containing block になりメニューがヘッダー内に閉じ込められるのを防ぐ */
  .site-header.nav-active{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .site-header.nav-active~.float-cta{opacity:0;pointer-events:none}
  .nav{background:rgba(255,255,255,.985)}
  .nav a{font-size:1.1rem;padding:10px 22px}
  .nav .btn{margin-left:0}
  .hero h1{font-size:clamp(1.7rem,7.6vw,2.3rem)}
  .family-grid{grid-template-columns:1fr}
  /* スマホ1列では親→子の縦点線が最初のカードだけにかかり意味不明になるため非表示 */
  .family-link{display:none}
  .family-center{margin-bottom:14px}
  .purpose-points{gap:10px}
  .pp{width:calc(50% - 10px)}
  .bubble{margin-left:48px;font-size:.88rem}
  .worry-bubbles .bubble:nth-child(2),.worry-bubbles .bubble:nth-child(4){margin-right:48px}
  .foot-grid{grid-template-columns:1fr}
  .news-item{padding:14px 18px}
  .float-cta{font-size:.82rem;padding:12px 16px}
  /* モバイルは <br> 強制改行を解除 */
  .lead br,.sec-lead br,.core p br{display:none}
  .lead br.sp-only{display:inline}
  .sec-lead br.lb{display:inline}
  /* スマホはマスコットが縮むので吹き出しも小さめに */
  .tax-mascot .speech{font-size:.8rem;padding:5px 15px;top:31px}
  /* 料金カードのPC専用改行・字詰めはスマホでは解除（スマホは自然な左寄せ折返しのまま） */
  .price-card .pcbr{display:none}
  .price-card .pdesc-d{letter-spacing:normal}
}
@media (max-width:480px){
  .band{margin-left:10px;margin-right:10px;padding:48px 16px;border-radius:24px}
  .pp{width:calc(50% - 5px)}
  .hero-cta .btn{width:100%}
  .core{padding:56px 20px}
}

/* ============ 下層ページ追加コンポーネント（全ページB案化） ============ */

/* 統合ストーリー */
.merge{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:stretch;max-width:880px;margin:36px auto 0}
.merge-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:30px 26px;text-align:left;border-top:7px solid var(--kanri)}
.merge-card.is-old2{border-top-color:var(--tax)}
.merge-card h3{font-size:1.05rem;margin:0 0 14px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.merge-card .tagn{display:inline-block;font-family:var(--maru);font-weight:800;font-size:.72rem;letter-spacing:.08em;color:var(--kanri);background:var(--kanri-bg);border-radius:999px;padding:3px 14px}
.merge-card.is-old2 .tagn{color:var(--tax);background:var(--tax-bg)}
.merge-card ul{margin:0;padding:0;list-style:none;font-size:.88rem;color:var(--ink-soft)}
.merge-card ul li{padding-left:1.2em;position:relative;margin-bottom:4px}
.merge-card ul li::before{content:"";position:absolute;left:0;top:.74em;width:8px;height:8px;border-radius:50%;background:var(--kanri-bg);border:1.5px solid var(--kanri)}
.merge-card.is-old2 ul li::before{background:var(--tax-bg);border-color:var(--tax)}
.merge-plus{align-self:center;font-family:var(--maru);font-weight:900;font-size:2rem;color:var(--moon-deep)}
.merge-result{max-width:680px;margin:28px auto 0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:24px 28px;text-align:center}
.merge-result .eq{margin:0 0 6px;font-family:var(--maru);font-weight:900;font-size:clamp(1.15rem,2.6vw,1.5rem);color:var(--navy-deep)}
.merge-result .eq span{color:var(--moon-deep);margin:0 .2em}
.merge-result small{color:var(--ink-soft);font-size:.82rem}

/* 4つの安心 */
.anshin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:24px}
.anshin-grid .a{background:var(--sky);border-radius:16px;padding:16px 10px;font-family:var(--maru);font-weight:800;font-size:.88rem;color:var(--navy-deep);display:flex;flex-direction:column;gap:4px;align-items:center}
.anshin-grid .a:nth-child(2){background:var(--mint)}
.anshin-grid .a:nth-child(3){background:var(--cream)}
.anshin-grid .a:nth-child(4){background:var(--sharo-bg)}
.anshin-grid .a small{font-family:var(--en);font-weight:700;font-size:.62rem;letter-spacing:.22em;color:var(--ink-soft)}

/* 2カラムカード */
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:780px;margin:0 auto}
.t-card{background:var(--sky);border-radius:var(--radius);padding:26px 24px;text-align:center}
.t-card:nth-child(2){background:var(--mint)}
.t-card h3{font-size:1.05rem;margin:0 0 10px}
.t-card p{margin:0;font-size:.86rem;color:var(--ink-soft);text-align:left}
.t-card .ic{width:52px;height:52px;margin:0 auto 12px}
.t-card .num{display:inline-block;font-family:var(--maru);font-weight:800;font-size:.85rem;color:var(--moon-deep);background:#fff;border-radius:999px;padding:4px 16px;margin-bottom:12px}
.t-card.future-card{background:var(--navy);color:#fff}
.t-card.future-card h3{color:#fff}
.t-card.future-card p{color:rgba(255,255,255,.8)}
.t-card.future-card .num{background:rgba(255,255,255,.14);color:var(--moon)}

/* ライフサイクルフロー */
.flow{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;margin-top:34px}
.flow .node{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:20px 22px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:108px}
.flow .node .ic{width:44px;height:44px}
.flow .node b{font-family:var(--maru);font-weight:800;font-size:.9rem;color:var(--navy-deep)}
.flow .arrow{font-family:var(--maru);font-weight:900;color:var(--moon-deep);font-size:1.4rem}
.flow-note{margin:24px auto 0;text-align:center;font-family:var(--maru);font-weight:700;font-size:.95rem;color:var(--navy-deep);background:#fff;border-radius:999px;padding:8px 24px;width:fit-content;box-shadow:var(--shadow-soft)}

/* 個人 vs グループ */
.vs{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:stretch;max-width:880px;margin:36px auto 0}
.vs-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:28px 26px;text-align:left;color:var(--ink)}
.vs-card h3{font-size:1.02rem;margin:0 0 14px;color:var(--navy-deep)}
.vs-card .lab{display:inline-block;font-family:var(--en);font-weight:700;font-size:.66rem;letter-spacing:.24em;color:var(--ink-soft);margin:10px 0 6px}
.vs-card .lab:first-of-type{margin-top:0}
.vs-card ul{margin:0 0 6px;padding:0;list-style:none;font-size:.88rem}
.vs-card li{padding-left:1.5em;position:relative;margin-bottom:5px;color:var(--ink-soft)}
.vs-card li.good::before{content:"✓";position:absolute;left:0;color:var(--tax);font-weight:900}
.vs-card li.bad::before{content:"×";position:absolute;left:0;color:var(--sharo);font-weight:900}
.vs-card.vs-group{border-top:7px solid var(--tax)}
.vs-card.vs-indiv{border-top:7px solid #C7CCD4}
.vs-mid{align-self:center;font-family:var(--maru);font-weight:900;font-size:2rem;color:var(--moon)}
.vs-concl{max-width:680px;margin:26px auto 0;text-align:center;font-size:.95rem;color:rgba(255,255,255,.85)}
.vs-concl b{color:var(--moon)}

/* サポート4ステップ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px;counter-reset:step}
.step-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:28px 20px 24px;text-align:center;position:relative;counter-increment:step}
.step-card::before{content:"STEP " counter(step);display:inline-block;font-family:var(--en);font-weight:700;font-size:.66rem;letter-spacing:.24em;color:var(--moon-deep);background:var(--cream);border-radius:999px;padding:4px 14px;margin-bottom:12px}
.step-card .ic{width:46px;height:46px;margin:0 auto 10px}
.step-card h3{font-size:.98rem;margin:0 0 8px}
.step-card p{margin:0;font-size:.82rem;color:var(--ink-soft)}

/* アクセス */
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1020px;margin:0 auto}
.access-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:30px 28px;text-align:left;display:flex;flex-direction:column}
.access-card .map-embed{margin-top:auto}
.access-card .badge{display:inline-block;border-radius:999px;padding:4px 16px;background:var(--tax-bg);color:var(--tax);margin-bottom:12px;font-family:var(--maru);font-weight:800;font-size:.76rem;letter-spacing:.06em}
.access-card h3{font-size:1.1rem;margin:0 0 16px}
.access-card dl{margin:0 0 18px;font-size:.86rem}
.access-card dt{font-family:var(--maru);font-weight:800;color:var(--navy-deep);font-size:.78rem;margin-top:10px;display:flex;align-items:center;gap:7px}
.access-card dt::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--moon)}
.access-card dd{margin:2px 0 0;color:var(--ink-soft);line-height:1.8}
.map-embed{border-radius:16px;overflow:hidden;border:1.5px solid rgba(61,86,128,.14)}
.map-embed iframe{display:block;width:100%;height:240px;border:0}

/* お問い合わせ */
.contact-alt{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:820px;margin:0 auto 34px}
.alt-card{background:#fff;border:2px dashed var(--moon-deep);border-radius:var(--radius);padding:20px 16px;text-align:center;display:block}
.alt-card b{display:block;font-family:var(--maru);font-weight:900;font-size:1rem;color:var(--navy-deep);margin-bottom:6px}
.alt-card span{display:block;font-size:.8rem;color:var(--ink-soft);line-height:1.8}
a.alt-card{transition:transform .25s,box-shadow .25s}
a.alt-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-soft)}
.contact-form{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);max-width:680px;margin:0 auto;padding:42px 38px;text-align:left}
.contact-form .field{margin-bottom:18px}
.contact-form label{display:block;font-family:var(--maru);font-weight:800;font-size:.86rem;color:var(--navy-deep);margin-bottom:7px}
.contact-form .req{display:inline-block;background:var(--sharo);color:#fff;font-size:.64rem;font-weight:700;border-radius:999px;padding:2px 10px;margin-left:8px;vertical-align:2px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;box-sizing:border-box;padding:13px 16px;border:1.5px solid rgba(61,86,128,.18);border-radius:14px;background:#fff;font-family:inherit;font-size:.95rem;color:var(--ink);transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--tax);box-shadow:0 0 0 4px rgba(95,165,114,.14)}
.contact-form textarea{min-height:130px;resize:vertical}
.contact-form select{appearance:none;-moz-appearance:none;cursor:pointer;padding-right:44px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%232C405F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:12px 8px}
.contact-form .center{text-align:center;margin-top:24px}
.form-note{font-size:.74rem;color:var(--ink-soft);margin:12px 0 0}

/* 税理士プロフィール */
.profile-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1040px;margin:38px auto 0;align-items:stretch}
.profile{display:flex;flex-direction:column;align-items:center;gap:18px;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:38px 32px;scroll-margin-top:84px}
.profile>div{width:100%}
.profile>div:not(.profile-photo){flex:1;display:flex;flex-direction:column}
.profile .profile-photo{flex:0 0 auto}
.profile-cta{margin-top:auto;padding-top:24px}
/* 税理士グリッドを上の代表カード（profile-row）と左右・間隔を揃える */
.staff-grid-wide{max-width:1040px;gap:24px}
.staff-grid-wide .staff-card{align-items:flex-start}
@media(max-width:934px){.staff-grid-wide{grid-template-columns:minmax(0,1fr);max-width:580px}}
.profile-photo{width:200px;height:200px;border-radius:50%;background:var(--sky);border:4px solid #fff;box-shadow:var(--shadow-soft);display:grid;place-items:center;font-size:.82rem;color:var(--ink-soft)}
.profile .role{display:block;font-size:.78rem;color:var(--moon-deep);font-weight:700;margin-bottom:2px}
.profile h2{font-size:1.5rem;margin:0 0 12px}
.profile h2 .en-name{font-family:var(--en);font-weight:600;font-size:.95rem;color:var(--moon-deep);margin-left:10px}
.profile>div>p{font-size:.92rem;color:var(--ink-soft);text-align:justify;word-break:normal;overflow-wrap:anywhere;line-height:1.95}
.profile h3{font-size:.95rem;margin:22px 0 8px;display:flex;align-items:center;gap:8px}
.profile h3::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--moon)}
.profile ul{margin:0;padding:0;list-style:none;font-size:.86rem;color:var(--ink-soft)}
.profile ul li{padding-left:1.2em;position:relative;margin-bottom:4px}
.profile ul li::before{content:"";position:absolute;left:0;top:.74em;width:7px;height:7px;border-radius:50%;background:var(--tax-bg);border:1.5px solid var(--tax)}
.profile ul li a{color:var(--moon-deep);text-decoration:underline}

/* キャラクター紹介 */
.chara{display:grid;grid-template-columns:260px 1fr;gap:32px;align-items:center;max-width:880px;margin:34px auto 0;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:36px 34px;text-align:left}
.chara-img img{width:100%;max-width:240px;margin:0 auto}
.chara-name{font-family:var(--maru);font-weight:900;font-size:1.4rem;color:var(--navy-deep);margin:0 0 14px}
.chara-name .en{font-family:var(--en);font-weight:700;font-size:.72rem;letter-spacing:.26em;color:var(--moon-deep);margin-left:12px}
.chara-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.chara-grid .c{margin:0;background:var(--cream);border-radius:12px;padding:10px 14px;font-size:.82rem}
.chara-grid .c dt{font-family:var(--maru);font-weight:800;color:var(--moon-deep);font-size:.72rem}
.chara-grid .c dd{margin:0;color:var(--ink)}
.chara-story{max-width:880px;margin:18px auto 0;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-soft);padding:28px 30px;text-align:left}
.chara-story h3{font-size:1rem;margin:0 0 8px;display:flex;align-items:center;gap:8px}
.chara-story h3::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--moon)}
.chara-story p{margin:0;font-size:.88rem;color:var(--ink-soft);text-align:justify}
.chara-greet{margin-top:26px;display:flex;justify-content:center}
.bubble2{position:relative;display:inline-block;background:#fff;border:2px solid var(--moon-deep);border-radius:22px;padding:18px 28px;font-family:var(--maru);font-weight:800;font-size:1rem;color:var(--navy-deep);line-height:1.9}
.bubble2 small{display:block;margin-top:8px;font-size:.72rem;color:var(--ink-soft);font-weight:700}

/* LINEマガジン */
.mag-subhead{display:inline-block;font-family:var(--maru);font-weight:800;font-size:.92rem;letter-spacing:.06em;color:var(--navy-deep);background:#FCEFCF;border:2px solid var(--moon);border-radius:999px;padding:5px 20px;margin:34px auto 2px}
.mag-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;max-width:880px;margin:14px auto 0}
.mag-card{display:block;text-align:center;text-decoration:none;transition:transform .25s}
.mag-card:hover{transform:translateY(-4px)}
.mag-thumb{display:block;width:100%;height:auto;aspect-ratio:595/842;object-fit:cover;border-radius:16px;border:2px solid #FBE7C2;box-shadow:var(--shadow-soft);background:#fff;transition:border-color .25s,box-shadow .25s}
.mag-card:hover .mag-thumb{border-color:var(--moon);box-shadow:var(--shadow)}
.mag-card b{display:block;margin-top:8px;font-family:var(--maru);font-weight:800;font-size:.8rem;color:var(--navy-deep);line-height:1.3}
.mag-card b small{display:block;font-size:.62rem;color:var(--moon-deep);font-weight:800;letter-spacing:.1em;margin-top:2px}
.mag-archive{grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px}
.mag-archive .mag-thumb{border-radius:12px}
.mag-archive .mag-card b{font-size:.72rem;margin-top:6px}
.mag-archive .mag-card b small{font-size:.56rem}
.mag-cta{margin-top:30px;text-align:center}
.mag-cta p{color:var(--ink-soft);font-size:.9rem;margin:0 0 14px}

/* ===== マガジン本棚（B案 ひだまりポップ） ===== */
.shelf-wrap{background:linear-gradient(160deg,#FFF7E8 0%,#FCE9C6 100%);border:2px solid #FBE7C2;border-radius:24px;padding:30px 26px 38px;max-width:920px;margin:18px auto 0;box-shadow:var(--shadow-soft)}
.shelf-yr-row{display:flex;align-items:center;gap:12px;margin:0 0 18px}
.shelf-yr-tag{font-family:var(--en);font-size:.9rem;font-weight:700;color:var(--moon-deep);letter-spacing:.1em;white-space:nowrap}
.shelf-yr-line{flex:1;height:2px;border-radius:2px;background:linear-gradient(90deg,var(--moon) 0%,transparent 100%);opacity:.55}
.shelf-yr-count{font-family:var(--maru);font-size:.76rem;font-weight:700;color:var(--ink-soft);white-space:nowrap}
.shelf-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px 12px;align-items:end;margin-bottom:34px}
.shelf-grid .mag-card{text-align:left;border-radius:3px 12px 12px 3px;border-left:6px solid var(--moon);overflow:hidden;background:#fff;box-shadow:4px 8px 22px rgba(180,130,40,.20),1px 2px 5px rgba(0,0,0,.08);transform-origin:bottom center}
.shelf-grid .mag-card .mag-thumb{border-radius:0 8px 8px 0;border:none;box-shadow:none}
.shelf-grid .mag-card:hover{transform:translateY(-10px) rotate(-1.2deg);box-shadow:8px 22px 38px rgba(180,130,40,.28),2px 4px 8px rgba(0,0,0,.12)}
.shelf-grid .mag-card:hover .mag-thumb{border:none;box-shadow:none}
.shelf-grid .mag-card b{display:block;margin:0;font-family:var(--maru);font-weight:800;font-size:.72rem;text-align:center;color:var(--navy-deep);padding:8px 4px 9px;background:#fff;line-height:1.4}
.shelf-grid .mag-card b small{display:inline;margin-left:5px;font-size:.82em;color:var(--moon-deep);letter-spacing:0}
.shelf-new{display:inline-block;background:var(--moon-deep);color:#fff;font-family:var(--en);font-size:.56rem;font-weight:700;padding:1px 6px;border-radius:20px;margin-left:5px;vertical-align:2px;letter-spacing:.04em}
.shelf-board{grid-column:1/-1;height:11px;background:linear-gradient(180deg,#E6C892 0%,#C79A52 52%,#9A6E32 100%);border-radius:3px;box-shadow:0 5px 13px rgba(120,80,20,.28),inset 0 1px 0 rgba(255,255,255,.35);margin-top:3px}
.shelf-toggle{display:flex;align-items:center;gap:9px;background:#fff;border:2px solid var(--moon);color:var(--moon-deep);font-family:var(--maru);font-size:.86rem;font-weight:800;border-radius:999px;padding:10px 26px;cursor:pointer;margin:6px auto 26px;transition:background .2s,color .2s;width:fit-content}
.shelf-toggle:hover{background:var(--moon);color:#fff}
.shelf-toggle-arrow{display:inline-block;transition:transform .25s}
.shelf-toggle.is-open .shelf-toggle-arrow{transform:rotate(180deg)}
@media(max-width:760px){.shelf-grid{grid-template-columns:repeat(3,1fr)}.shelf-wrap{padding:22px 16px 30px}}
@media(max-width:440px){.shelf-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== 誌面ビューアー モーダル（B案） ===== */
.mag-modal{position:fixed;inset:0;z-index:200;display:none}
.mag-modal.is-open{display:block}
.mag-modal-bg{position:absolute;inset:0;background:rgba(44,40,30,.62)}
.mag-modal-inner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:min(920px,94vw);height:92vh;background:#fff;border-radius:22px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.mag-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 22px;border-bottom:2px solid #FBE7C2;background:#FFFDF7}
.mag-modal-title{font-family:var(--maru);color:var(--navy-deep);font-weight:800;font-size:1rem}
.mag-modal-act{display:flex;align-items:center;gap:16px}
.mag-modal-x{cursor:pointer;border:none;background:transparent;font-size:1.7rem;line-height:1;color:var(--ink-soft);padding:0 2px}
.mag-modal-x:hover{color:var(--navy-deep)}
.mag-modal-body{flex:1;background:#3f3b34;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mag-modal-pages{max-width:760px;margin:0 auto;padding:18px 18px 30px;display:flex;flex-direction:column;gap:14px}
.mag-page{width:100%;display:block;border-radius:5px;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.3)}
@media(max-width:560px){.mag-modal-inner{width:100vw;height:100dvh;border-radius:0}.mag-modal-pages{padding:12px 10px 22px;gap:10px}}

/* 税理士法人サイト：ヘッダー上の「◂ メイトグループ サイトへ」バー */
.site-switch{
  display:block;background:var(--sky);
  font-family:var(--maru);font-weight:700;font-size:.76rem;letter-spacing:.06em;
  color:var(--navy);padding:7px 0;line-height:1.5;
  border-bottom:1px solid rgba(61,86,128,.1);
  transition:background .25s,color .25s;
}
.site-switch .wrap{display:block;text-align:right}
.site-switch:hover{background:var(--kanri-bg);color:var(--navy-deep)}

/* フッター前ナビ（← 前のページへ／TOPへ戻る） */
.back-nav{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap;padding:38px 20px 6px}
.bn-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--maru);font-weight:800;font-size:.86rem;color:var(--navy);background:#fff;border:2px solid rgba(61,86,128,.22);border-radius:999px;padding:11px 26px;cursor:pointer;transition:border-color .25s,background .25s,transform .25s}
.bn-btn:hover{border-color:var(--navy);background:var(--sky);transform:translateY(-2px)}

@media (max-width:880px){
  .merge,.vs{grid-template-columns:1fr;max-width:560px}
  .merge-plus,.vs-mid{justify-self:center}
  .steps{grid-template-columns:1fr 1fr}
  .access-grid{grid-template-columns:1fr}
  .anshin-grid{grid-template-columns:1fr 1fr}
  .profile-row{grid-template-columns:1fr;max-width:580px}
  .profile{padding:32px 22px}
  .profile>div{width:100%}
  .chara{grid-template-columns:1fr;justify-items:center}
  .chara-grid{width:100%}
}
@media (max-width:640px){
  .two,.steps,.contact-alt{grid-template-columns:1fr}
  .staff-grid-wide .staff-card{flex-direction:column;align-items:center;text-align:center}
  .flow .arrow{display:none}
  .flow .node{min-width:calc(50% - 10px)}
  .contact-form{padding:30px 20px}
  .chara-grid{grid-template-columns:1fr}
  .mag-grid{grid-template-columns:repeat(2,1fr)}
  /* スマホ実機ではみ出していた箇所の調整（2026-06-11） */
  .purpose-card{padding:36px 18px 32px}
  .purpose-card .big{font-size:clamp(1.05rem,5vw,1.3rem)}
  .core h2{font-size:clamp(1.3rem,5.8vw,1.7rem)}
  .vm-statement{font-size:clamp(1.12rem,5vw,1.4rem)}
  .worry-punch .big{font-size:clamp(1.1rem,4.8vw,1.7rem)}
  .btn{font-size:.9rem;padding:13px 22px;flex-wrap:wrap;max-width:100%;row-gap:0;line-height:1.7}
}

/* 税理士紹介：プロフィール写真（実写真・円形に収める） */
.profile .profile-photo{overflow:hidden;padding:0;display:block;width:200px;height:200px;margin-left:auto;margin-right:auto}
.profile-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 16%;border-radius:50%;display:block}

/* 税理士法人TOP 税理士紹介teaser：96px円形アバターに実写真 */
.staff-photo{overflow:hidden;padding:0;display:block}
.staff-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 12%;border-radius:50%;display:block}
