/* ============================================================
   さかがみ会計事務所 — style.css（2026-06 デザイン刷新）
   基調   : 白 × 淡いグリーン × 深いフォレストグリーン ＋ 真鍮
   見出し : Noto Serif JP ／ 本文 : Noto Sans JP ／ 欧文 : Inter
   ============================================================ */

/* ========== Design Tokens ========== */
:root{
  /* greens */
  --g900:#1e3f2c;
  --g800:#26513a;
  --g700:#31654a;
  --g600:#3f7d5d;
  --g500:#55946f;
  --g400:#7bb492;
  --g300:#a9cdb7;
  --g200:#cfe5d7;
  --g100:#e6f2ea;
  --g50:#f3f8f4;
  /* brass accent */
  --brass:#a8b57e;
  --brass-deep:#87935d;
  --brass-soft:#cdd8a4;
  /* neutrals */
  --ink:#1b231e;--ink2:#424b44;--ink3:#68716a;--ink4:#99a39b;
  --line:#e2e8e1;--line2:#ecf0ea;
  --paper:#f4f8f2;--paper2:#e9f1e7;
  --bg:#fff;--white:#fff;
  /* legacy aliases */
  --green:#3f7d5d;--green2:#31654a;--green3:#26513a;
  --green-soft:#e6f2ea;--green-ghost:rgba(63,125,93,.08);--green-bg:#f3f8f4;
  /* effects */
  --shadow-sm:0 1px 2px rgba(18,28,21,.05);
  --shadow-md:0 10px 30px -12px rgba(18,28,21,.14);
  --shadow-lg:0 24px 60px -20px rgba(18,28,21,.22);
  --radius:12px;--radius-sm:8px;--radius-lg:18px;
  /* type */
  --jp:"Noto Sans JP",system-ui,sans-serif;
  --serif:"Noto Serif JP","Hiragino Mincho ProN",serif;
  --jp-s:var(--serif);
  --en:"Inter",system-ui,sans-serif;
  --en-s:var(--serif);
  --mono:var(--en);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:92px}
body{font-family:var(--jp);background:var(--bg);color:var(--ink);font-size:16px;line-height:1.85;-webkit-font-smoothing:antialiased;font-feature-settings:"palt" 1}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul,ol{list-style:none}

/* ========== Layout ========== */
.container{max-width:1200px;margin:0 auto;padding:0 32px}
.section{padding:112px 0}
.section-sm{padding:72px 0}
@media(max-width:768px){.container{padding:0 20px}.section{padding:72px 0}.section-sm{padding:56px 0}}

/* ========== Typography ========== */
.h-display{font-family:var(--serif);font-weight:600;font-size:clamp(26px,calc(4.5vw - 6px),52px);line-height:1.34;letter-spacing:.015em;color:var(--ink)}
.h-display .block{display:block}
.sec-title{font-family:var(--serif);font-weight:600;font-size:clamp(25px,3vw,37px);line-height:1.45;letter-spacing:.02em;color:var(--ink)}
.h-card{font-family:var(--serif);font-weight:600;font-size:21px;line-height:1.6;letter-spacing:.02em}
.lede{font-size:15.5px;line-height:2.05;color:var(--ink2);max-width:62ch}

/* 見出し眉ラベル（番号 + 罫線 + 英語） */
.sec-head{display:flex;flex-direction:column;gap:18px;align-items:flex-start;margin-bottom:56px}
.sec-head.center{align-items:center;text-align:center}
.eyebrow{display:flex;align-items:center;gap:14px;font-family:var(--en);font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--g600)}
.eyebrow-num{letter-spacing:.08em}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--g500)}
.sec-head.center .eyebrow::before{display:none}
.sec-head--invert .eyebrow{color:var(--brass-soft)}
.sec-head--invert .eyebrow::before{background:var(--brass-soft)}
.sec-head--invert .sec-title{color:#fff}

/* ========== Buttons ========== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:54px;padding:0 30px;font-size:14px;font-weight:600;border:1.5px solid transparent;transition:all .22s;letter-spacing:.04em;border-radius:10px;white-space:nowrap}
.btn .arrow{display:inline-block;transition:transform .22s}
.btn:hover .arrow{transform:translateX(4px)}
.btn-primary{background:var(--g800);color:#fff;border-color:var(--g800);box-shadow:0 6px 18px -8px rgba(38,81,58,.55)}
.btn-primary:hover{background:var(--g700);border-color:var(--g700);transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(38,81,58,.5)}
.btn-secondary{background:#fff;color:var(--g800);border-color:var(--g800)}
.btn-secondary:hover{background:var(--g50);transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--g700);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--g400);background:var(--g50)}
.btn-white{background:#fff;color:var(--g800);border-color:#fff;font-weight:700}
.btn-white:hover{transform:translateY(-1px);box-shadow:0 10px 24px -8px rgba(0,0,0,.3)}
.btn-invert{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-invert:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-sm{height:42px;padding:0 18px;font-size:12.5px;border-radius:8px}
.btn:disabled{cursor:not-allowed}
.tlink{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--g700);transition:gap .2s}
.tlink:hover{gap:14px}
.tlink::after{content:"→"}

/* ========== Header ========== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line2);transition:box-shadow .24s}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:78px;transition:height .24s}
.site-header.scrolled .header-inner{height:64px}
.logo-img{height:40px;width:auto;transition:height .24s}
.site-header.scrolled .logo-img{height:32px}
.nav-desktop{display:flex;gap:26px;align-items:center}
.nav-desktop a{font-size:13.5px;font-weight:500;letter-spacing:.03em;color:var(--ink2);transition:color .15s;position:relative;padding:5px 0}
.nav-desktop a:hover{color:var(--g700)}
.nav-desktop a::after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--g600);transition:width .2s}
.nav-desktop a:hover::after{width:100%}
.nav-desktop a.current{color:var(--g800);font-weight:600}
.nav-desktop a.current::after{width:100%}
.nav-utils{display:flex;align-items:center;gap:16px}
.nav-tel{font-family:var(--en);font-size:15.5px;font-weight:700;letter-spacing:.02em;color:var(--g800)}
.nav-tel-label{font-family:var(--jp);font-size:10px;letter-spacing:.1em;color:var(--ink3);display:block;margin-bottom:-1px;font-weight:500}
.menu-btn{display:none;width:44px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff}
.menu-btn .bar{display:block;width:18px;height:1.5px;background:var(--ink);border-radius:1px}
@media(max-width:1060px){.nav-desktop{display:none!important}.nav-tel{display:none}.menu-btn{display:flex!important}}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:60;background:var(--bg);padding:24px;display:flex;flex-direction:column;gap:24px;transform:translateX(100%);transition:transform .3s}
body.menu-open{overflow:hidden}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-head{display:flex;justify-content:space-between;align-items:center}
.mobile-menu-head .logo-img{height:30px}
.menu-close{width:44px;height:44px;border:1px solid var(--line);border-radius:var(--radius-sm);font-size:18px;display:flex;align-items:center;justify-content:center}
.mobile-menu nav{display:flex;flex-direction:column;margin-top:8px}
.mobile-menu nav a{padding:17px 2px;border-bottom:1px solid var(--line2);font-size:15.5px;font-weight:500;display:flex;justify-content:space-between;align-items:center}
.mobile-menu nav a .go{color:var(--g500);font-family:var(--en)}
.mobile-menu-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px}
.mobile-menu-foot .pair{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ========== HERO ========== */
.hero-section{position:relative;overflow:hidden;background:#eff1ec}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(102deg,rgba(255,255,255,.86) 0%,rgba(255,255,255,.68) 28%,rgba(255,255,255,.3) 55%,rgba(255,255,255,0) 75%)}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;max-width:1280px;margin:0 auto;padding:0 32px;min-height:clamp(620px,88vh,860px);align-items:center}
.hero-text{padding:150px 0 110px;max-width:640px}
.hero-badge{display:inline-flex;align-items:center;gap:10px;font-size:13px;color:var(--g800);font-weight:600;letter-spacing:.05em;background:rgba(255,255,255,.92);border:1px solid var(--g200);padding:7px 18px;border-radius:99px;margin-bottom:30px;box-shadow:var(--shadow-sm)}
.hero-badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--g500)}
.hero-title{margin:0 0 26px}
.hero-lede{margin:0 0 42px;font-size:15.5px;line-height:2.1;color:var(--ink2);max-width:46ch}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-tel{background:rgba(255,255,255,.95);color:var(--g800);border-color:var(--g300)}
.btn-tel:hover{border-color:var(--g600)}
.btn-tel .tel-label{font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--ink3)}
.btn-tel .tel-num{font-family:var(--en);font-size:16.5px;font-weight:700;letter-spacing:.02em}
/* 実績ストリップ（枠箱→罫線区切りの編集的スタイル） */
.trust-strip{margin-top:60px;padding-top:26px;border-top:1px solid rgba(27,35,30,.16);display:flex;gap:44px}
.trust-item .t-label{font-size:11px;font-weight:600;letter-spacing:.16em;color:var(--ink3);margin-bottom:6px}
.trust-item .t-value{font-size:16.5px;font-weight:700;line-height:1.5;color:var(--ink)}
.trust-item .t-sub{font-size:12px;color:var(--ink3);margin-top:3px}
/* 人物 */
.hero-photo-col{position:relative;display:flex;align-items:flex-end;justify-content:center;padding-top:60px}
.hero-photo-col::before{content:"";position:absolute;left:50%;bottom:-12%;transform:translateX(-50%);width:130%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(123,180,146,.22) 0%,rgba(123,180,146,.07) 45%,transparent 68%);pointer-events:none}
.hero-person-img{position:relative;width:100%;max-width:540px;height:auto;filter:drop-shadow(0 30px 50px rgba(20,40,28,.22))}

@media(max-width:1024px){
  .hero-grid{padding:0 24px}
  .hero-text{padding:130px 0 84px}
  .trust-strip{gap:32px}
}
/* モバイル: 背景写真の左側（壁＋葉影）を縦スライスで使用。テキスト→実績→人物の縦組み */
@media(max-width:768px){
  .hero-section{background:#eff1ec}
  .hero-bg{background-position:14% center}
  .hero-scrim{background:linear-gradient(180deg,rgba(255,255,255,.82) 0%,rgba(255,255,255,.55) 38%,rgba(255,255,255,.25) 70%,rgba(255,255,255,.1) 100%)}
  .hero-grid{min-height:0;padding:0 20px}
  .hero-text{padding:118px 0 60px}
  .h-display{font-size:26px;letter-spacing:.01em}
  .hero-badge{margin-bottom:22px}
  .hero-lede{font-size:14.5px;line-height:2.0;margin-bottom:30px}
  .hero-buttons{flex-direction:column;align-items:stretch;gap:10px}
  .hero-buttons .btn{width:100%}
  .trust-strip{flex-direction:column;gap:0;margin-top:36px;padding-top:6px}
  .trust-item{display:flex;align-items:baseline;gap:14px;padding:13px 2px;border-bottom:1px solid rgba(27,35,30,.1)}
  .trust-item:last-child{border-bottom:none}
  .trust-item .t-label{margin:0;flex-shrink:0}
  .trust-item .t-value{font-size:14.5px}
  .trust-item .t-sub{margin:0 0 0 auto;text-align:right;flex-shrink:0}
}

/* ========== STRENGTHS（罫線のみの編集的タイル） ========== */
.strength-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.strength-card{padding-top:30px;border-top:1px solid var(--ink);display:flex;flex-direction:column}
.strength-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:26px}
.strength-num{font-family:var(--en);font-size:15px;font-weight:600;letter-spacing:.1em;color:var(--g700)}
.strength-tag{font-family:var(--en);font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink4)}
.strength-card .h-card{margin:0 0 16px;white-space:pre-line}
.strength-body{font-size:14px;line-height:2.0;color:var(--ink2);margin:0 0 28px}
.strength-foot{margin-top:auto;font-size:12px;letter-spacing:.04em;color:var(--ink3);padding-top:14px;border-top:1px solid var(--line)}
@media(max-width:880px){.strength-grid{grid-template-columns:1fr;gap:36px}}

/* ========== SERVICES ========== */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc-card{padding:38px 34px 30px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);display:flex;flex-direction:column;transition:all .25s;box-shadow:var(--shadow-sm)}
.svc-card:hover{border-color:var(--g400);box-shadow:var(--shadow-md);transform:translateY(-4px)}
.svc-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px}
.svc-num{font-family:var(--en);font-size:15px;font-weight:600;letter-spacing:.1em;color:var(--g700)}
.svc-en{font-family:var(--en);font-size:11.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink4)}
.svc-title{font-weight:700;font-size:20px;letter-spacing:.02em;margin:0 0 14px}
.svc-desc{font-size:13.5px;line-height:1.95;color:var(--ink2);margin:0 0 24px}
.svc-tags{padding:0;margin:0 0 30px;display:flex;flex-wrap:wrap;gap:7px}
.svc-tags li{font-size:11.5px;font-weight:500;color:var(--g800);padding:5px 13px;background:var(--g50);border:1px solid var(--g100);border-radius:99px}
.svc-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:18px;border-top:1px solid var(--line)}
.svc-foot span:first-child{font-size:13px;font-weight:600;color:var(--g700)}
.svc-arrow{color:var(--g700);transition:transform .2s}
.svc-card:hover .svc-arrow{transform:translateX(5px)}
@media(max-width:640px){.svc-grid{grid-template-columns:1fr}}

/* ========== AI SUPPORT（深緑の帯＝ページ中盤のリズム） ========== */
.ai-section{background:linear-gradient(160deg,var(--g900) 0%,var(--g800) 100%);position:relative;overflow:hidden;color:#fff}
.ai-section::before{content:"";position:absolute;right:-120px;top:-60px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(205,216,164,.14) 0%,transparent 62%);pointer-events:none}
.ai-section::after{content:"";position:absolute;left:-80px;bottom:-120px;width:380px;height:380px;border-radius:50%;border:1px solid rgba(255,255,255,.07);pointer-events:none}
.ai-head{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:end;margin-bottom:64px;position:relative}
.ai-section .lede{color:rgba(255,255,255,.82)}
.ai-policy{border:1px solid rgba(205,216,164,.45);padding:30px 34px;background:rgba(255,255,255,.05);border-radius:var(--radius);backdrop-filter:blur(4px)}
.ai-policy-label{font-size:12.5px;font-weight:600;letter-spacing:.08em;color:var(--brass-soft);margin-bottom:12px}
.ai-policy p{margin:0;font-size:16px;line-height:1.95;font-weight:500;color:#fff}
.ai-policy .em{color:var(--brass-soft)}
.ai-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;position:relative}
.ai-card{padding:30px 30px 28px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:var(--radius);transition:all .25s}
.ai-card:hover{background:rgba(255,255,255,.1);border-color:rgba(205,216,164,.5);transform:translateY(-2px)}
.ai-num{font-family:var(--en);font-size:13px;font-weight:600;letter-spacing:.14em;color:var(--brass-soft);margin-bottom:16px}
.ai-card h3{font-size:16.5px;font-weight:600;margin:0 0 12px;line-height:1.55;color:#fff}
.ai-card p{font-size:13px;line-height:1.95;color:rgba(255,255,255,.76);margin:0}
.ai-foot{margin-top:52px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;position:relative}
.ai-foot p{margin:0;font-size:12.5px;line-height:1.9;color:rgba(255,255,255,.62);max-width:52ch}
@media(max-width:880px){.ai-head{grid-template-columns:1fr;gap:32px}}
@media(max-width:640px){.ai-grid{grid-template-columns:1fr}.ai-policy{padding:24px 24px}}

/* ========== SOUZOKU ========== */
.sz-head{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:end;margin-bottom:64px}
.renkei-box{padding:34px 36px;background:var(--paper);border:1px solid var(--line2);position:relative;border-radius:var(--radius)}
.renkei-label{position:absolute;top:-13px;left:28px;background:var(--bg);padding:2px 14px;font-size:12px;font-weight:600;color:var(--g700);border:1px solid var(--line);border-radius:99px}
.renkei-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.renkei-row .joint{flex:1;height:1px;background:var(--brass);opacity:.55;margin-top:40px}
.pillar-col{display:flex;flex-direction:column;align-items:center;gap:9px;flex-shrink:0}
.pillar-cap{font-size:11px;line-height:1.45;color:var(--ink3);text-align:center;letter-spacing:.01em}
.pillar{width:82px;height:82px;border:1px solid var(--g300);background:#fff;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:15.5px;font-weight:600;letter-spacing:.1em;color:var(--ink2)}
.pillar.active{background:var(--g800);border-color:var(--g800);color:#fff}
.renkei-box .note{margin:24px 0 0;font-size:12.5px;color:var(--ink2);line-height:1.85}
.sz-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.sz-card{padding:38px 36px;background:var(--paper);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:16px;transition:all .25s}
.sz-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.sz-card-head{display:flex;align-items:baseline;justify-content:space-between}
.sz-card-head .p-num{font-size:12px;font-weight:600;letter-spacing:.06em;color:var(--g700)}
.sz-card-head .p-tag{font-size:11.5px;color:var(--ink4);font-weight:500}
.sz-card h3{font-family:var(--serif);font-size:23px;font-weight:600;margin:0;letter-spacing:.02em}
.sz-pill{display:inline-block;width:fit-content;padding:6px 16px;border:1px solid var(--g400);color:var(--g800);font-size:12px;font-weight:500;border-radius:99px;background:#fff}
.sz-card p{margin:0;font-size:13.5px;line-height:1.95;color:var(--ink2)}
@media(max-width:880px){.sz-head{grid-template-columns:1fr;gap:32px}.sz-grid{grid-template-columns:1fr}}

/* ========== FLOW ========== */
.flow-section{background:var(--g50)}
.flow-grid{display:flex;gap:0;align-items:flex-start;justify-content:center;flex-wrap:wrap;margin-top:56px;position:relative}
.flow-step{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;min-width:150px;max-width:210px;position:relative;padding:0 10px}
.flow-step:not(:last-child)::after{content:"";position:absolute;right:calc(-50% + 36px);top:33px;width:calc(100% - 72px);height:1px;background:var(--g300)}
.flow-num{width:66px;height:66px;border-radius:50%;background:#fff;color:var(--g800);display:flex;align-items:center;justify-content:center;font-family:var(--en);font-size:17px;font-weight:700;margin-bottom:16px;border:1.5px solid var(--g500);position:relative;z-index:1;box-shadow:var(--shadow-sm)}
.flow-title{font-size:14.5px;font-weight:700;margin-bottom:7px}
.flow-desc{font-size:12.5px;color:var(--ink3);line-height:1.75}
@media(max-width:640px){
  .flow-grid{flex-direction:column;align-items:stretch;gap:0;margin-top:40px}
  .flow-step{max-width:100%;flex-direction:row;gap:18px;text-align:left;padding:15px 0;align-items:flex-start}
  .flow-step:not(:last-child)::after{display:none}
  .flow-num{width:48px;height:48px;font-size:14px;margin:0;flex-shrink:0}
  .flow-step>div{padding-top:3px}
}

/* ========== PRICING ========== */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.price-card{padding:38px 32px 32px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:17px;box-shadow:var(--shadow-sm);transition:all .25s}
.price-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.price-head{display:flex;align-items:baseline;justify-content:space-between}
.price-plan{font-size:12.5px;font-weight:600;color:var(--g700);letter-spacing:.08em}
.price-for{font-size:11px;color:var(--ink3)}
.price-name{font-family:var(--serif);font-size:25px;font-weight:600;margin:2px 0 0;letter-spacing:.03em}
.price-amount{display:flex;align-items:baseline;gap:8px;padding-bottom:20px;border-bottom:1px solid var(--line)}
.price-amount .num{font-family:var(--en);font-size:36px;font-weight:700;letter-spacing:-.01em;color:var(--g800)}
.price-amount .unit{font-size:12px;color:var(--ink3)}
.price-desc{margin:0;font-size:13px;line-height:1.9;color:var(--ink2)}
.price-list{padding:0;margin:0;display:flex;flex-direction:column;gap:11px}
.price-list li{display:flex;align-items:flex-start;gap:10px;font-size:13px}
.price-list .check{color:var(--g600);font-size:13px;font-weight:700;padding-top:1px}
.price-card .btn{margin-top:auto}
/* featured = 深緑 */
.price-card.featured{position:relative;background:linear-gradient(165deg,var(--g800) 0%,var(--g900) 100%);color:#fff;border-color:var(--g800);transform:translateY(-10px);box-shadow:var(--shadow-lg)}
.price-card.featured:hover{transform:translateY(-14px)}
.price-card.featured .price-plan{color:var(--brass-soft)}
.price-card.featured .price-for{color:rgba(255,255,255,.65)}
.price-card.featured .price-amount{border-bottom-color:rgba(255,255,255,.25)}
.price-card.featured .price-amount .num{color:#fff}
.price-card.featured .price-amount .unit{color:rgba(255,255,255,.7)}
.price-card.featured .price-desc{color:rgba(255,255,255,.82)}
.price-card.featured .price-list .check{color:var(--brass-soft)}
.reco-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--brass);color:#fff;padding:6px 20px;font-size:11.5px;font-weight:700;letter-spacing:.12em;border-radius:99px;box-shadow:0 4px 12px -4px rgba(135,147,93,.6)}
.price-note{margin-top:44px;padding:22px 26px;background:var(--g50);border-left:3px solid var(--brass);display:flex;gap:18px;align-items:flex-start;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.price-note .label{font-size:12px;font-weight:700;color:var(--g800);padding-top:2px;white-space:nowrap}
.price-note p{margin:0;font-size:12.5px;line-height:1.95;color:var(--ink2)}
@media(max-width:960px){.price-grid{grid-template-columns:1fr}.price-card.featured{transform:none}.price-card.featured:hover{transform:translateY(-3px)}.price-note{flex-direction:column;gap:8px}}

/* ========== GREETING ========== */
.greet-grid{display:grid;grid-template-columns:5fr 7fr;gap:64px;align-items:flex-start}
.greet-photo{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius-lg);background:url('../images/hero_photo.webp') 74% center/cover no-repeat}
.greet-photo::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,0) 45%)}
.greet-photo img{position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:80%;height:auto;filter:drop-shadow(0 18px 28px rgba(20,40,28,.2))}
.greet-namecard{margin:-44px 20px 0;position:relative;padding:20px 24px;border:1px solid var(--line);background:rgba(255,255,255,.96);backdrop-filter:blur(6px);border-radius:var(--radius);box-shadow:var(--shadow-md)}
.greet-namecard .role{font-size:12px;font-weight:600;color:var(--g700);margin-bottom:5px;letter-spacing:.06em}
.greet-namecard .name{font-family:var(--serif);font-size:24px;font-weight:600;letter-spacing:.1em}
.greet-namecard .en{font-family:var(--en);font-size:11.5px;color:var(--ink3);margin-top:3px;letter-spacing:.04em}
.greet-quote{margin:44px 0 32px;padding:0 0 0 26px;border-left:2px solid var(--g600);font-family:var(--serif);font-size:clamp(19px,2vw,23px);font-weight:600;line-height:1.95;color:var(--ink);letter-spacing:.03em}
.greet-body{font-size:14.5px;line-height:2.15;color:var(--ink2);display:flex;flex-direction:column;gap:20px}
.greet-body p{margin:0}
.greet-stats{margin-top:44px;display:flex;gap:40px;flex-wrap:wrap;padding-top:30px;border-top:1px solid var(--line)}
.greet-stats .gs-label{font-size:11.5px;font-weight:500;letter-spacing:.1em;color:var(--ink3);margin-bottom:5px}
.greet-stats .gs-value{font-family:var(--en);font-size:21px;font-weight:700;color:var(--g800);letter-spacing:.01em}
.greet-stats .gs-value.jp{font-family:var(--jp);font-size:17px}
.greet-actions{margin-top:36px;display:flex;gap:12px;flex-wrap:wrap}
@media(max-width:880px){.greet-grid{grid-template-columns:1fr;gap:44px}}

/* ========== FAQ ========== */
.faq-grid{display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:flex-start}
.faq-side{position:sticky;top:110px}
.faq-list{border-top:1px solid var(--ink)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-btn{width:100%;padding:24px 2px;display:flex;align-items:flex-start;gap:18px;text-align:left;background:none;border:none;transition:background .15s}
.faq-btn:hover .faq-q{color:var(--g700)}
.faq-num{font-family:var(--en);font-size:14px;font-weight:600;letter-spacing:.08em;color:var(--g600);min-width:48px;padding-top:2px}
.faq-q{flex:1;font-size:15.5px;font-weight:600;line-height:1.7;transition:color .15s}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s}
.faq-answer.open{max-height:600px}
.faq-answer-inner{padding:2px 0 30px 66px;font-size:14px;line-height:2.0;color:var(--ink2)}
.faq-toggle{color:var(--g700);transition:all .25s;line-height:1;width:28px;height:28px;border:1.5px solid var(--g400);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;margin-top:1px}
.faq-toggle.open{transform:rotate(45deg);background:var(--g800);border-color:var(--g800);color:#fff}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr;gap:36px}.faq-side{position:static}.faq-answer-inner{padding-left:0}}

/* ========== NEWS（カード→編集的なリスト行） ========== */
.news-head-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;gap:24px;flex-wrap:wrap}
.news-head-row .sec-head{margin-bottom:0}
.news-list{border-top:1px solid var(--ink)}
.news-row{display:flex;align-items:center;gap:22px;padding:22px 6px;border-bottom:1px solid var(--line);transition:background .15s}
.news-row:hover{background:#fff}
.news-date{font-family:var(--en);font-size:12.5px;font-weight:500;color:var(--ink3);letter-spacing:.04em;min-width:84px}
.news-tag{padding:4px 13px;font-size:10.5px;font-weight:600;border:1px solid var(--g300);color:var(--g800);border-radius:99px;background:#fff;white-space:nowrap}
.news-title{flex:1;font-size:15px;font-weight:600;margin:0;line-height:1.7}
.news-go{color:var(--g600);font-family:var(--en);transition:transform .2s}
.news-row:hover .news-go{transform:translateX(5px)}
@media(max-width:640px){.news-row{flex-wrap:wrap;gap:8px 10px;padding:16px 2px}.news-title{flex-basis:100%;order:4;margin-top:2px}.news-go{margin-left:auto;order:3}}

/* ========== ACCESS ========== */
.access-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:64px;align-items:flex-start}
.info-grid{margin:0;display:grid;grid-template-columns:auto 1fr;column-gap:28px;row-gap:0}
.info-grid dt{font-size:13px;font-weight:600;color:var(--g800);padding:15px 0;border-bottom:1px solid var(--line2);letter-spacing:.04em;white-space:nowrap}
.info-grid dd{margin:0;font-size:14px;line-height:1.85;padding:15px 0 15px;border-bottom:1px solid var(--line2)}
.info-grid a{font-weight:600;color:var(--g700)}
.map-wrap{position:relative;aspect-ratio:4/3;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.map-wrap iframe{border:0;position:absolute;inset:0;width:100%;height:100%}
.map-card{position:absolute;left:18px;bottom:18px;background:rgba(255,255,255,.97);padding:16px 20px;border:1px solid var(--line);max-width:260px;border-radius:var(--radius);box-shadow:var(--shadow-md)}
.map-card .area{font-size:11.5px;font-weight:600;color:var(--g700);margin-bottom:4px;letter-spacing:.06em}
.map-card .station{font-size:14px;font-weight:700;line-height:1.6}
@media(max-width:880px){.access-grid{grid-template-columns:1fr;gap:40px}}

/* ========== CTA Banner ========== */
.cta-banner{background:linear-gradient(150deg,var(--g800) 0%,var(--g900) 100%);color:#fff;padding:80px 0;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;right:-100px;top:-110px;width:340px;height:340px;border-radius:50%;border:1px solid rgba(205,216,164,.25)}
.cta-banner::after{content:"";position:absolute;left:-60px;bottom:-80px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(205,216,164,.13) 0%,transparent 65%)}
.cta-eyebrow{font-size:13px;margin:0 0 14px;color:var(--brass-soft);font-weight:600;letter-spacing:.14em}
.cta-title{font-family:var(--serif);font-size:clamp(23px,3vw,34px);font-weight:600;margin:0 0 14px;line-height:1.6;letter-spacing:.02em}
.cta-sub{font-size:14.5px;margin:0 0 34px;color:rgba(255,255,255,.85)}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* ========== CONTACT ========== */
.contact-section{background:linear-gradient(180deg,var(--paper) 0%,#fff 100%)}
.cc-grid{display:grid;grid-template-columns:5fr 7fr;gap:56px;align-items:flex-start}
.contact-info-col{position:sticky;top:110px}
.contact-channels{margin-top:42px;padding:28px 28px;background:#fff;border:1px solid var(--line);display:flex;flex-direction:column;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.channel{display:flex;align-items:flex-start;gap:16px;padding:15px 0;border-bottom:1px dashed var(--line)}
.channel:first-child{padding-top:0}
.channel:last-child{border-bottom:none;padding-bottom:0}
.channel .ch-label{font-family:var(--en);font-size:11.5px;font-weight:700;letter-spacing:.14em;color:var(--g700);min-width:44px;padding-top:4px}
.channel .ch-value{font-size:16.5px;font-weight:700;letter-spacing:.02em}
.channel .ch-note{font-size:11.5px;color:var(--ink3);margin-top:2px}
.contact-form{padding:42px 40px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.form-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:34px;padding-bottom:22px;border-bottom:1px solid var(--line)}
.form-head .t{font-family:var(--serif);font-size:19px;font-weight:600}
.form-head .req{font-size:11px;color:var(--ink3)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:22px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--ink2);margin-bottom:8px}
.form-label .must{color:var(--g600)}
.form-input{width:100%;padding:14px 16px;border:1px solid var(--line);background:#fbfdfa;font-size:14px;font-family:var(--jp);border-radius:10px;outline:none;color:var(--ink);transition:all .2s}
.form-input:focus{border-color:var(--g500);background:#fff;box-shadow:0 0 0 3px rgba(85,148,111,.16)}
.form-block{margin-bottom:22px}
.chip-row{display:flex;gap:8px;flex-wrap:wrap}
.topic-btn,.method-btn{padding:10px 18px;font-size:13px;border:1px solid var(--line);background:#fff;color:var(--ink2);transition:all .15s;cursor:pointer;border-radius:99px}
.topic-btn.active,.method-btn.active{border-color:var(--g800);background:var(--g800);color:#fff}
.topic-btn:hover,.method-btn:hover{border-color:var(--g500)}
.agree-row{display:flex;gap:10px;align-items:flex-start;margin:28px 0;cursor:pointer;font-size:13px;color:var(--ink2);line-height:1.75}
.agree-row input{margin-top:4px;accent-color:var(--g700)}
.agree-row a{color:var(--g700);text-decoration:underline;font-weight:500}
.form-actions{display:flex;gap:12px;flex-wrap:wrap}
.thank-you-box{max-width:720px;margin:0 auto;padding:64px 48px;text-align:center;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}
.thank-you-box .big{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--g800);margin-bottom:18px}
.thank-you-box h3{font-family:var(--serif);font-size:22px;font-weight:600;margin:0 0 18px}
@media(max-width:880px){.cc-grid{grid-template-columns:1fr;gap:40px}.form-row{grid-template-columns:1fr}.contact-info-col{position:static}.contact-form{padding:30px 22px}}

/* ========== FOOTER ========== */
.site-footer{background:var(--g900);color:rgba(255,255,255,.82);padding-top:76px;padding-bottom:30px;position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,rgba(205,216,164,.4),transparent)}
.ft-grid{display:grid;grid-template-columns:1.3fr 2.2fr;gap:56px;padding-bottom:52px;border-bottom:1px solid rgba(255,255,255,.13)}
.ft-brand-name{font-family:var(--serif);font-size:23px;font-weight:600;color:#fff;letter-spacing:.05em}
.ft-brand-en{font-family:var(--en);font-size:12px;color:var(--brass-soft);margin-top:5px;letter-spacing:.16em;text-transform:uppercase}
.ft-address{margin:30px 0 0;font-size:13px;line-height:2.05;color:rgba(255,255,255,.72)}
.ft-badges{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap}
.badge{font-size:11px;padding:7px 14px;border:1px solid rgba(205,216,164,.4);color:rgba(255,255,255,.85);display:inline-block;border-radius:99px}
.ft-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.ft-col-head{font-size:12.5px;font-weight:600;color:rgba(255,255,255,.95);margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.14);letter-spacing:.05em}
.ft-link{font-size:13px;color:rgba(255,255,255,.66);transition:all .15s;display:block;padding:5px 0}
.ft-link:hover{color:#fff;padding-left:4px}
.ft-bottom{padding-top:26px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.ft-copy{font-size:11px;color:rgba(255,255,255,.45);letter-spacing:.04em}
.ft-bottom-links{display:flex;gap:22px;font-size:11.5px}
.ft-bottom-links a{color:rgba(255,255,255,.6);transition:color .15s}
.ft-bottom-links a:hover{color:#fff}
@media(max-width:880px){.ft-grid{grid-template-columns:1fr;gap:44px}.ft-cols{grid-template-columns:repeat(2,1fr)}}

/* ========== STICKY DOCK (mobile) ========== */
.sticky-dock{position:fixed;left:0;right:0;bottom:0;z-index:40;display:none;grid-template-columns:1fr 1fr 1.5fr;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);box-shadow:0 -6px 24px rgba(18,28,21,.08);padding-bottom:env(safe-area-inset-bottom)}
.dock-item{padding:11px 0 12px;text-align:center;color:var(--g800)}
.dock-item+.dock-item{border-left:1px solid var(--line2)}
.dock-item .d-label{font-size:10.5px;letter-spacing:.12em;color:var(--ink3);margin-bottom:2px;font-family:var(--en);font-weight:600}
.dock-item .d-main{font-size:13px;font-weight:700}
.dock-item.dock-cta{background:var(--g800);color:#fff;border-left:none}
.dock-item.dock-cta .d-label{color:var(--brass-soft)}
@media(max-width:768px){.sticky-dock{display:grid}body{padding-bottom:calc(72px + env(safe-area-inset-bottom))}}

/* ========== Utilities ========== */
:focus-visible{outline:2px solid var(--g600);outline-offset:3px}
.fade-up{opacity:0;transform:translateY(16px);transition:opacity .8s cubic-bezier(.2,.6,.2,1),transform .8s cubic-bezier(.2,.6,.2,1)}
.fade-up.visible{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.fade-up{opacity:1;transform:none}}
.bg-white{background:var(--bg)}
.bg-paper{background:var(--paper)}
.bg-green-soft{background:var(--g50)}

/* ========== COLUMN INDEX / ARTICLE（下層ページ） ========== */
.page-hero{padding:132px 0 8px;background:linear-gradient(180deg,var(--g50) 0%,#fff 100%)}
.page-hero .sec-title{margin-top:4px}
.article{padding:118px 0 88px}
.article-wrap{max-width:768px}
.crumb{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--ink3);margin-bottom:30px;flex-wrap:wrap}
.crumb a{color:var(--g700)}
.crumb a:hover{text-decoration:underline}
.crumb span{color:var(--ink4)}
.crumb .cur{color:var(--ink3);max-width:32ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.article-head{padding-bottom:30px;border-bottom:1px solid var(--line);margin-bottom:44px}
.article-tag{display:inline-block;padding:5px 14px;font-size:11px;font-weight:600;border:1px solid var(--g300);color:var(--g800);border-radius:99px;background:var(--g50);margin-bottom:20px}
.article-title{font-family:var(--serif);font-size:clamp(24px,3.4vw,35px);font-weight:600;line-height:1.5;letter-spacing:.02em;color:var(--ink);margin:0 0 18px}
.article-date{font-family:var(--en);font-size:13px;color:var(--ink3);letter-spacing:.05em}
.article-body{font-size:15.5px;line-height:2.05;color:var(--ink2)}
.article-body>*:first-child{margin-top:0}
.article-note{background:var(--g50);border-left:3px solid var(--brass);border-radius:6px;padding:12px 16px;margin:0 0 1.8em;font-size:12.5px;line-height:1.8;color:var(--ink3)}
.article-body p{margin:0 0 1.6em}
.article-body h2{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);margin:2em 0 .8em;padding-bottom:.4em;border-bottom:1px solid var(--line);letter-spacing:.02em}
.article-body h3{font-size:18px;font-weight:700;color:var(--ink);margin:1.8em 0 .6em}
.article-body a{color:var(--g700);text-decoration:underline;text-underline-offset:2px}
.article-body a:hover{color:var(--g600)}
.article-body ul,.article-body ol{margin:0 0 1.6em;padding-left:1.4em}
.article-body li{margin:0 0 .5em;line-height:1.9}
.article-body ul li{list-style:disc}
.article-body ol li{list-style:decimal}
.article-body img{height:auto;border-radius:var(--radius);margin:1.6em 0;box-shadow:var(--shadow-sm)}
.article-body blockquote{margin:1.6em 0;padding:14px 24px;border-left:3px solid var(--g500);background:var(--g50);color:var(--ink2);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.article-body strong{font-weight:700;color:var(--ink)}
.article-body table{width:100%;border-collapse:collapse;margin:1.6em 0;font-size:14px}
.article-body th,.article-body td{border:1px solid var(--line);padding:10px 14px;text-align:left}
.article-body th{background:var(--g50);font-weight:600}
.article-foot{margin-top:56px;padding-top:34px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
@media(max-width:640px){
  .page-hero{padding-top:104px}
  .article{padding:96px 0 64px}
  .article-foot{flex-direction:column-reverse}
  .article-foot .btn{width:100%}
}

/* ========== FEE PAGE（報酬一覧） ========== */
.fee-wrap{max-width:880px}
.fee-block{margin-bottom:60px}
.fee-h{font-family:var(--serif);font-size:clamp(20px,2.6vw,26px);font-weight:600;color:var(--ink);margin:0 0 20px;padding-bottom:14px;border-bottom:2px solid var(--g800);letter-spacing:.02em}
.fee-h3{font-size:16px;font-weight:700;color:var(--g800);margin:30px 0 14px}
.fee-unit{font-family:var(--jp);font-size:11.5px;font-weight:500;color:var(--ink3);margin-left:10px}
.fee-lead{font-size:14.5px;line-height:1.95;color:var(--ink2);margin:0 0 24px}
.fee-callout{background:var(--g50);border:1px solid var(--g100);border-radius:var(--radius);padding:24px 28px}
.fee-callout-main{font-size:18px;color:var(--ink);margin-bottom:8px}
.fee-callout-main strong{color:var(--g800)}
.fee-callout p{margin:0;font-size:13.5px;line-height:1.9;color:var(--ink2)}
.fee-callout strong{color:var(--g800)}
.fee-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-sm)}
.tbl-hint{display:none;font-size:11px;color:var(--ink3);margin:0 0 6px;text-align:right;letter-spacing:.03em}
@media(max-width:640px){.tbl-hint{display:block}}
.fee-table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:480px}
.fee-table--2col{min-width:0}
.fee-table th,.fee-table td{border:1px solid var(--line);padding:11px 14px;text-align:left;vertical-align:top;line-height:1.7}
.fee-table thead th{background:var(--g800);color:#fff;font-weight:600;font-size:12.5px;white-space:nowrap;border-color:var(--g800)}
.fee-table tbody tr:nth-child(even){background:var(--g50)}
.fee-table td:first-child{font-weight:500;color:var(--ink)}
.fee-soudan{color:var(--g700);font-weight:600}
.fee-mark{color:var(--g600);font-weight:600;font-size:.85em}
.fee-note{font-size:12px;line-height:1.85;color:var(--ink3);margin:12px 0 0}
.fee-note strong{color:var(--ink2)}
.fee-list{margin:0 0 24px;padding-left:1.35em;font-size:14.5px;line-height:1.95;color:var(--ink2)}
.fee-list li{margin:0 0 .55em;list-style:disc}
.fee-list li strong{color:var(--g800);font-weight:600}
.fee-def{margin:0 0 20px;font-size:14px;line-height:1.9;color:var(--ink2)}
.fee-def dt{font-weight:600;color:var(--g800);margin:16px 0 4px}
.fee-def dt:first-child{margin-top:0}
.fee-def dd{margin:0 0 0}
.fee-meta{font-size:13px;line-height:1.9;color:var(--ink3);margin:28px 0 0;padding-top:18px;border-top:1px solid var(--line)}
.fee-meta strong{color:var(--ink2)}
/* 設立応援プラン */
.startup-plan{position:relative;background:linear-gradient(160deg,var(--g50),#fff);border:1.5px solid var(--g300);border-radius:var(--radius-lg);padding:36px 34px}
.startup-plan-tag{display:inline-block;background:var(--brass);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.1em;padding:5px 16px;border-radius:99px;margin-bottom:14px}
.startup-plan-sub{font-size:14px;color:var(--ink2);margin:0 0 24px;line-height:1.9}
.startup-plan-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
.startup-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px;text-align:center}
.startup-card .sp-label{font-size:13px;font-weight:600;color:var(--g700);margin-bottom:10px}
.startup-card .sp-price{font-size:16px;color:var(--ink2)}
.startup-card .sp-price strong{font-family:var(--en);font-size:30px;color:var(--g800);letter-spacing:-.01em;margin-left:4px}
.startup-card .sp-sub{font-size:11.5px;color:var(--ink3);margin-top:8px;line-height:1.6}
.startup-plan-note{font-size:12px;line-height:1.9;color:var(--ink2);margin:0}
.startup-plan-note a{color:var(--g700);text-decoration:underline}
@media(max-width:560px){.startup-plan-grid{grid-template-columns:1fr}.startup-plan{padding:28px 22px}}
.fee-cta{margin-top:44px;padding:34px;background:var(--g50);border-radius:var(--radius-lg);text-align:center}
.fee-cta p{font-size:13px;color:var(--ink2);margin:0 0 20px;line-height:1.9}
/* ===== 顧問プラン（報酬ページ） ===== */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:6px}
.plan-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px 26px;display:flex;flex-direction:column;gap:12px}
.plan-card.featured{border:1.5px solid var(--g600);box-shadow:var(--shadow-md)}
.plan-en{font-family:var(--en);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--g600)}
.plan-name{font-family:var(--serif);font-size:24px;font-weight:600;letter-spacing:.02em}
.plan-target{font-size:12px;color:var(--ink3);line-height:1.75;margin:0;min-height:38px}
.plan-list{display:flex;flex-direction:column;gap:8px;margin:4px 0 6px;padding:0}
.plan-list li{position:relative;padding-left:18px;font-size:13px;line-height:1.75;color:var(--ink2)}
.plan-list li::before{content:"✓";position:absolute;left:0;color:var(--g600);font-weight:700;font-size:12px}
.plan-price-line{margin-top:auto;padding-top:14px;border-top:1px solid var(--line);font-size:13px;color:var(--ink2);line-height:1.7}
.plan-price-line strong{font-family:var(--en);font-size:19px;color:var(--g800)}
@media(max-width:880px){.plan-grid{grid-template-columns:1fr}.plan-target{min-height:0}}
/* 比較表 */
.cmp-table th,.cmp-table td{text-align:center}
.cmp-table th:first-child,.cmp-table td:first-child{text-align:left}
.cmp-ok{color:var(--g600);font-weight:700}
.cmp-no{color:var(--ink4)}
/* ===== 報酬シミュレーター ===== */
.sim-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-sm)}
.sim-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px 16px;padding:14px 0;border-bottom:1px dashed var(--line2)}
.sim-label{min-width:128px;font-size:13px;font-weight:600;color:var(--ink2)}
.sim-chips{display:flex;gap:8px;flex-wrap:wrap}
.sim-chip{padding:9px 16px;font-size:13px;border:1px solid var(--line);background:#fff;color:var(--ink2);border-radius:99px;cursor:pointer;transition:all .15s}
.sim-chip:hover{border-color:var(--g500)}
.sim-chip.active{background:var(--g800);border-color:var(--g800);color:#fff}
.sim-chip.disabled{opacity:.35;pointer-events:none}
.sim-select{padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:#fbfdfa;font-size:13.5px;font-family:var(--jp);color:var(--ink);outline:none}
.sim-select:focus{border-color:var(--g500)}
.sim-result{margin-top:22px;background:var(--g50);border-radius:var(--radius);padding:22px 26px}
.sim-line{display:flex;justify-content:space-between;gap:12px;font-size:13.5px;padding:7px 0;border-bottom:1px dashed var(--line)}
.sim-line .v{font-family:var(--en);font-weight:600;white-space:nowrap}
.sim-total{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding-top:14px;font-weight:700;font-size:14.5px}
.sim-total .v{font-family:var(--en);font-size:26px;color:var(--g800)}
.sim-annual{display:flex;justify-content:space-between;align-items:baseline;gap:12px;font-size:13px;color:var(--ink2);margin-top:6px}
.sim-annual .v{font-family:var(--en);font-weight:700;font-size:17px;color:var(--g700)}
.sim-note{font-size:11.5px;color:var(--ink3);line-height:1.85;margin:14px 0 0}
.sim-soudan{text-align:center;padding:22px 10px}
.sim-soudan .t{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--g800);margin-bottom:8px}
.sim-soudan p{font-size:13px;color:var(--ink2);margin:0;line-height:1.9}
@media(max-width:640px){.sim-label{min-width:100%}.sim-card{padding:20px 16px}.sim-result{padding:18px 16px}}
/* ===== 相続専門サイト バナー ===== */
.sister-banner{margin-top:28px;background:linear-gradient(135deg,var(--g800),var(--g900));border-radius:var(--radius-lg);padding:34px 38px;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative;overflow:hidden}
.sister-banner::before{content:"";position:absolute;right:-70px;top:-70px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(205,216,164,.16),transparent 65%);pointer-events:none}
.sister-tag{display:inline-block;background:var(--brass);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.1em;padding:4px 13px;border-radius:99px;margin-bottom:12px}
.sister-banner h3{font-family:var(--serif);font-size:clamp(18px,2.2vw,23px);font-weight:600;margin:0 0 10px;color:#fff;letter-spacing:.02em}
.sister-banner p{margin:0;font-size:13px;line-height:1.95;color:rgba(255,255,255,.82);max-width:54ch}
.sister-banner .btn{flex-shrink:0;position:relative}
@media(max-width:640px){.sister-banner{padding:26px 22px}.sister-banner .btn{width:100%}}

/* ===== トップのプラン紹介（金額なし） ===== */
.plan-mini-en{font-family:var(--en);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--g600);margin-bottom:6px}
.plan-mini-name{font-family:var(--serif);font-size:21px;font-weight:600;margin-bottom:10px}
.plan-mini-text{font-size:13px;line-height:1.9;color:var(--ink2)}
.reco-chip{display:inline-block;background:var(--brass);color:#fff;font-size:10.5px;font-weight:700;letter-spacing:.08em;padding:3px 11px;border-radius:99px;margin-left:8px;vertical-align:2px}

/* ===== 予約タブ＋Google予約スケジュール埋め込み ===== */
.bk-tabs{display:inline-flex;background:var(--g50);border:1px solid var(--line);border-radius:99px;padding:4px;margin-bottom:22px;gap:4px;max-width:100%}
.bk-tab{padding:9px 18px;font-size:13px;font-weight:600;border:none;background:transparent;color:var(--ink2);border-radius:99px;cursor:pointer;transition:all .15s;white-space:nowrap}
.bk-tab.active{background:var(--g800);color:#fff}
.bk-tab:hover:not(.active){color:var(--g700)}
.bk-panel{display:none}
.bk-panel.active{display:block}
.bk-embed{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:#fff}
.bk-embed iframe{width:100%;border:0;display:block;min-height:640px}
.bk-placeholder{border:1.5px dashed var(--g300);border-radius:var(--radius-lg);background:var(--g50);padding:44px 28px;text-align:center}
.bk-ph-badge{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--g700);background:#fff;border:1px solid var(--g200);border-radius:99px;padding:5px 14px;margin-bottom:16px}
.bk-ph-title{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--ink);margin-bottom:12px}
.bk-placeholder p{font-size:13px;line-height:1.95;color:var(--ink2);max-width:42ch;margin:0 auto 22px}
.bk-ph-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.bk-note{font-size:12px;color:var(--ink3);line-height:1.85;margin:16px 2px 0}
/* 汎用チップ・任意項目見出し */
.chip{padding:9px 16px;font-size:13px;border:1px solid var(--line);background:#fff;color:var(--ink2);transition:all .15s;cursor:pointer;border-radius:99px}
.chip.active{border-color:var(--g800);background:var(--g800);color:#fff}
.chip:hover:not(.active){border-color:var(--g500)}
.form-single{margin-bottom:22px}
.form-optional-head{margin:26px 0 16px;padding-top:18px;border-top:1px dashed var(--line);font-size:12px;font-weight:600;color:var(--ink3)}
.bk-field-note{font-size:11.5px;color:var(--ink3);line-height:1.7;margin:10px 2px 0}
.bk-phone-err{font-size:11.5px;color:#c0392b;line-height:1.6;margin:6px 2px 0}
.skip-link{position:absolute;left:-9999px;top:0;z-index:3000;background:var(--g900);color:#fff;padding:10px 18px;border-radius:0 0 8px 0;font-size:13px;text-decoration:none}
.skip-link:focus{left:0}
/* iOS Safari の入力フォーカス時自動ズーム防止（16px未満だとズームされる） */
@media(max-width:768px){.form-input,.sim-select{font-size:16px}}
@media(max-width:880px){.bk-embed iframe{min-height:560px}}
/* ===== GAS予約ウィジェット ===== */
.bk-widget{min-height:180px}
.bk-w-demo{font-size:11.5px;color:var(--brass-deep);background:#fffdf4;border:1px solid var(--brass-soft);border-radius:8px;padding:9px 13px;margin-bottom:16px;line-height:1.75}
.bk-w-lead{font-size:13.5px;color:var(--ink2);margin:0 0 16px;line-height:1.85}
.bk-w-load{font-size:13px;color:var(--ink3);padding:26px;text-align:center}
.bk-w-days{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 12px;-webkit-overflow-scrolling:touch}
.bk-w-day{flex:0 0 auto;min-width:62px;padding:11px 8px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;text-align:center;transition:all .15s;line-height:1.3}
.bk-w-day:hover{border-color:var(--g500)}
.bk-w-day.active{border-color:var(--g800);background:var(--g800);color:#fff}
.bk-w-day .dnum{display:block;font-family:var(--en);font-size:15px;font-weight:700}
.bk-w-day .dwd{display:block;font-size:11px;margin-top:3px;opacity:.85}
.bk-w-times{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.bk-w-time{padding:9px 17px;border:1px solid var(--line);border-radius:99px;background:#fff;font-family:var(--en);font-size:14px;font-weight:500;color:var(--ink);cursor:pointer;transition:all .15s}
.bk-w-time:hover{border-color:var(--g600);background:var(--g50)}
.bk-w-empty{font-size:12.5px;color:var(--ink3);line-height:1.85;padding:14px 2px}
.bk-w-back{background:none;border:none;color:var(--g700);font-size:13px;font-weight:600;cursor:pointer;padding:0;margin-bottom:16px}
.bk-w-back:hover{text-decoration:underline}
.bk-w-chosen{background:var(--g50);border:1px solid var(--g100);border-radius:10px;padding:13px 18px;margin-bottom:22px;font-size:14.5px;font-weight:600;color:var(--g800)}
.bk-w-err{font-size:12.5px;color:#a32d2d;margin-top:12px;line-height:1.7}
.bk-w-done{text-align:center;padding:34px 18px}
.bk-w-done .big{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--g800);margin-bottom:14px}
.bk-w-done .when{display:inline-block;background:var(--g50);border:1px solid var(--g100);border-radius:8px;padding:8px 16px;font-weight:600;color:var(--ink);margin:0 0 16px}
.bk-w-done p{font-size:13.5px;color:var(--ink2);line-height:1.95;max-width:40ch;margin:0 auto}
/* 月カレンダー */
.bk-cal-wrap{display:flex;gap:28px;flex-wrap:wrap;align-items:flex-start}
.bk-cal-wrap[hidden]{display:none}
.bk-cal{flex:0 0 auto;width:332px;max-width:100%;border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 16px 12px;background:#fff;box-shadow:var(--shadow-sm)}
.bk-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.bk-cal-title{font-weight:700;font-size:15px;color:var(--ink);letter-spacing:.02em}
.bk-cal-nav{width:34px;height:34px;border:1px solid var(--line);border-radius:8px;background:#fff;cursor:pointer;font-size:18px;color:var(--g700);display:flex;align-items:center;justify-content:center;line-height:1;padding:0}
.bk-cal-nav:hover:not(:disabled){border-color:var(--g500);background:var(--g50)}
.bk-cal-nav:disabled{opacity:.3;cursor:default}
.bk-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.bk-cal-wd{text-align:center;font-size:11px;color:var(--ink3);padding:2px 0 7px;font-weight:600}
.bk-cal-wd:first-child{color:#c0563c}
.bk-cal-wd:last-child{color:#3f74a8}
.bk-cal-day{aspect-ratio:1;border:none;background:none;border-radius:9px;font-family:var(--en);font-size:14px;color:var(--ink3);display:flex;align-items:center;justify-content:center;position:relative;padding:0}
.bk-cal-day.is-empty{visibility:hidden}
.bk-cal-day.is-disabled{color:var(--ink4);opacity:.5}
.bk-cal-day.is-available{cursor:pointer;color:var(--g800);font-weight:600}
.bk-cal-day.is-available::after{content:"";position:absolute;bottom:6px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--g500)}
.bk-cal-day.is-available:hover{background:var(--g50)}
.bk-cal-day.is-selected{background:var(--g800);color:#fff;font-weight:700}
.bk-cal-day.is-selected::after{background:#fff}
.bk-cal-side{flex:1 1 220px;min-width:200px}
.bk-cal-side-date{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:14px}
.bk-cal-side .bk-w-times{margin-top:0}
.bk-cal-hint{font-size:12px;color:var(--ink3);line-height:1.8;margin-top:4px}
.bk-cal-hint .bk-dot{color:var(--g500)}
@media(max-width:560px){.bk-cal{width:100%}.bk-cal-wrap{gap:20px}}
/* ホームの報酬要約 */
.fee-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.fee-sum-card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px 26px;box-shadow:var(--shadow-sm);transition:all .25s}
.fee-sum-card:hover{border-color:var(--g400);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.fee-sum-label{font-size:13px;font-weight:600;color:var(--g700);margin-bottom:12px}
.fee-sum-price{font-size:16px;color:var(--ink2);display:flex;align-items:baseline;gap:4px}
.fee-sum-price strong{font-family:var(--en);font-size:32px;color:var(--g800);letter-spacing:-.01em}
.fee-sum-price span{font-size:14px;color:var(--ink3)}
.fee-sum-note{font-size:12px;color:var(--ink3);margin-top:12px;line-height:1.75}
@media(max-width:760px){.fee-summary{grid-template-columns:1fr}}
/* 下層ページ：手順タイムライン・箇条書き */
.process{counter-reset:step;margin:6px 0 0}
.process-step{position:relative;padding:0 0 30px 30px;margin-left:18px;border-left:2px solid var(--g200)}
.process-step:last-child{border-left-color:transparent;padding-bottom:2px}
.process-step::before{counter-increment:step;content:counter(step);position:absolute;left:-19px;top:-4px;width:36px;height:36px;border-radius:50%;background:var(--g800);color:#fff;font-family:var(--en);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 0 0 4px #fff}
.process-step h4{font-size:16px;font-weight:700;margin:5px 0 8px;color:var(--ink);letter-spacing:.01em}
.process-step p{font-size:13.5px;line-height:1.95;color:var(--ink2);margin:0}
.page-ul{margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.page-ul li{position:relative;padding-left:24px;font-size:14.5px;line-height:1.85;color:var(--ink2)}
.page-ul li::before{content:"";position:absolute;left:5px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--g500)}
