/* AI活用支援 LP — scoped under .hb-ai-lp (テーマ干渉防止) */
@charset "UTF-8";


/* ============================================================================
   LP本体スタイル（.hb-ai-lp スコープ）— heart-and-brain-ai-lp.css と同一
   ============================================================================ */
.hb-ai-lp, .hb-ai-lp *{ box-sizing:border-box; }
.hb-ai-lp h1,.hb-ai-lp h2,.hb-ai-lp h3,.hb-ai-lp h4,.hb-ai-lp h5,.hb-ai-lp h6{ font-weight:900 !important; }
.hb-ai-lp b,.hb-ai-lp strong{ font-weight:700; }
.hb-ai-lp{
  --navy:#2E3E7D; --navy-dark:#222B3B; --blue:#3167C4; --bluegray:#8796D2;
  --ink:#2B2B2B; --ink-sub:#5A6070; --paper:#FFFFFF; --paper-2:#F9F9F9;
  --line:#DFDFDF; --rule:#2B2B2B; --radius:4px; --maxw:1120px; --pad:28px;
  font-family:'Noto Sans JP',-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif !important;
  color:var(--ink); font-size:16px; line-height:1.85; letter-spacing:.01em;
  -webkit-font-smoothing:antialiased; background:var(--paper);
  position:relative; z-index:0; /* LP全体を最背面の重なり文脈に固定し、ヘッダー(get_header)を常に前面に */
}
.hb-ai-lp *{ margin:0; padding:0; }
.hb-ai-lp img{ max-width:100%; display:block; }
.hb-ai-lp a{ text-decoration:none; opacity:1; }
.hb-ai-lp a:hover{ opacity:1; } /* テーマ common.css の a:hover{opacity:.6} を無効化（LPは独自hover） */
.hb-ai-lp .en{ font-family:'Outfit',sans-serif; }
.hb-ai-lp .inner{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); width:100%; }
.hb-ai-lp section{ padding:clamp(78px,10vh,132px) 0; position:relative; }
.hb-ai-lp .sec-head{ margin-bottom:50px; max-width:790px; }
.hb-ai-lp .eyebrow{ display:flex; align-items:center; gap:12px; font-family:'Outfit',sans-serif;
  font-weight:700; letter-spacing:.14em; font-size:12px; color:var(--navy); margin-bottom:22px; text-transform:uppercase; }
.hb-ai-lp .eyebrow .num{ font-size:12px; opacity:.55; }
.hb-ai-lp .eyebrow::after{ content:""; flex:0 0 40px; height:1px; background:var(--navy); }
.hb-ai-lp .sec-title{ font-size:clamp(25px,3.3vw,40px); font-weight:900; line-height:1.5; letter-spacing:.02em; margin-bottom:18px; color:var(--ink); }
.hb-ai-lp .sec-lead{ font-size:16px; color:var(--ink-sub); max-width:680px; line-height:1.95; }
.hb-ai-lp .sec-title,
.hb-ai-lp .thesis .big,
.hb-ai-lp .thesis p,
.hb-ai-lp .sec-lead,
.hb-ai-lp .founder h2,
.hb-ai-lp .founder p,
.hb-ai-lp .finalcta h2,
.hb-ai-lp .finalcta p{ word-break:auto-phrase; line-break:strict; }
.hb-ai-lp u.nv{ text-decoration:none; border-bottom:5px solid var(--navy); padding-bottom:1px; }
.hb-ai-lp .btn{ display:inline-flex; align-items:center; justify-content:center; gap:12px; font-weight:700;
  font-size:15px; line-height:1.5; padding:17px 32px; border-radius:var(--radius);
  transition:background .25s,color .25s,border-color .25s; cursor:pointer; border:1.5px solid var(--navy);
  white-space:nowrap; text-align:center; font-family:inherit; }
.hb-ai-lp .btn .arr{ transition:transform .25s; }
.hb-ai-lp .btn:hover .arr{ transform:translateX(5px); }
.hb-ai-lp .btn-primary{ background:var(--navy); color:#fff; }
.hb-ai-lp .btn-primary:hover{ background:var(--navy-dark); }
.hb-ai-lp .btn-ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.hb-ai-lp .btn-ghost:hover{ background:var(--ink); color:#fff; }
.hb-ai-lp .btn-light{ background:#fff; color:var(--navy); border-color:#fff; }
.hb-ai-lp .btn-light:hover{ background:transparent; color:#fff; border-color:#fff; }
.hb-ai-lp .micro{ font-size:12.5px; color:var(--ink-sub); margin-top:14px; }
.hb-ai-lp .hero{ background:linear-gradient(150deg,#dff0f4 0%,#c8e6f0 30%,#b8dce8 50%,#d4eef6 75%,#eaf6fa 100%);
  color:var(--ink); padding:clamp(150px,18vh,210px) 0 clamp(86px,11vh,128px); position:relative; overflow:hidden; }
.hb-ai-lp .hero .tagline{ font-family:'Outfit',sans-serif; font-weight:600; letter-spacing:.2em; font-size:12.5px;
  color:var(--navy); margin-bottom:32px; text-transform:uppercase; display:flex; align-items:center; gap:14px; }
.hb-ai-lp .hero .tagline::before{ content:""; width:42px; height:1px; background:var(--navy); display:inline-block; }
.hb-ai-lp .hero h1{ font-size:clamp(29px,5.2vw,60px); font-weight:900; line-height:1.45; letter-spacing:.03em; margin-bottom:32px; color:var(--navy-dark); }
.hb-ai-lp .hero h1 .l{ display:block; }
.hb-ai-lp .hero h1 u.nv{ border-bottom-color:var(--blue); }
.hb-ai-lp .hero .sub{ font-size:clamp(15px,1.9vw,19px); color:var(--ink-sub); max-width:34em; margin-bottom:40px; line-height:2.05; }
.hb-ai-lp .hero .cta-row{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.hb-ai-lp .hero .micro{ color:var(--ink-sub); }
/* ヒーロー：白ベール＋シアンのパーティクル（uravation風・ライト基調・CSS＋軽量Canvas） */
.hb-ai-lp .hero .inner{ position:relative; z-index:3; }
.hb-ai-lp .hero-bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hb-ai-lp .hero-bg::before{ content:""; position:absolute; inset:0;
  background:linear-gradient(100deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.55) 40%, rgba(255,255,255,.12) 72%),
    radial-gradient(120% 95% at 0% 0%, rgba(255,255,255,.7), rgba(255,255,255,0) 55%); }
.hb-ai-lp .hero-particles{ position:absolute; inset:0; z-index:1; width:100%; height:100%; opacity:.75; pointer-events:none; }
.hb-ai-lp .marquee{ background:var(--navy); overflow:hidden; padding:32px 0; }
.hb-ai-lp .marquee .track{ display:flex; width:max-content; animation:hbMarquee 32s linear infinite; }
.hb-ai-lp .marquee .item{ font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(46px,7.5vw,118px);
  line-height:1; color:#5b6cb0; letter-spacing:-.01em; padding-right:80px; white-space:nowrap; mix-blend-mode:overlay; }
@keyframes hbMarquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
.hb-ai-lp .logoband{ background:#fff; padding:1em 0; border-bottom:1px solid var(--line); }
.hb-ai-lp .logo-marquee{ overflow:hidden; width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent); }
.hb-ai-lp .logo-marquee .lm-track{ display:flex; width:max-content; animation:hbLogoMarquee 45s linear infinite; }
.hb-ai-lp .logo-marquee:hover .lm-track{ animation-play-state:paused; }
.hb-ai-lp .logo-marquee .lm-set{ display:flex; align-items:center; list-style:none; }
.hb-ai-lp .logo-marquee .lm-set li{ flex:0 0 auto; padding:0 .5em; display:flex; align-items:center; }
.hb-ai-lp .logo-marquee .lm-set img{ height:30px; width:auto; max-width:none; object-fit:contain; }
@keyframes hbLogoMarquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }
@media(prefers-reduced-motion:reduce){ .hb-ai-lp .logo-marquee .lm-track{ animation:none; } }
@media(max-width:520px){ .hb-ai-lp .logoband{ padding:.5em 0; } .hb-ai-lp .logo-marquee .lm-set img{ height:25px; } }
.hb-ai-lp .empathy{ background:var(--paper-2); }
.hb-ai-lp .checklist{ border-top:1px solid var(--rule); max-width:880px; }
.hb-ai-lp .chk{ display:grid; grid-template-columns:34px 1fr; gap:18px; align-items:start; padding:25px 0; border-bottom:1px solid var(--line); }
.hb-ai-lp .chk .box{ width:26px; height:26px; border:2px solid var(--navy); border-radius:3px; position:relative; margin-top:3px; }
.hb-ai-lp .chk .box::after{ content:""; position:absolute; left:7px; top:3px; width:8px; height:13px;
  border-right:2.5px solid var(--navy); border-bottom:2.5px solid var(--navy); transform:rotate(45deg); }
.hb-ai-lp .chk p{ font-size:clamp(15px,1.8vw,18px); font-weight:500; line-height:1.7; }
.hb-ai-lp .empathy .note{ margin-top:24px; font-size:14px; color:var(--navy); font-weight:700; }
.hb-ai-lp .thesis{ background:var(--paper); }
.hb-ai-lp .thesis .big{ font-size:clamp(20px,2.7vw,29px); font-weight:900; line-height:1.85; letter-spacing:.02em; max-width:24em; color:var(--ink); }
.hb-ai-lp .thesis .big .nv{ border-bottom:5px solid var(--navy); }
.hb-ai-lp .thesis p{ margin-top:26px; font-size:16px; color:var(--ink-sub); max-width:40em; line-height:2; }
.hb-ai-lp .reasons{ background:var(--paper-2); }
.hb-ai-lp .rgrid{ display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--rule); }
.hb-ai-lp .rcard{ padding:44px 32px 44px 32px; border-bottom:1px solid var(--line); }
.hb-ai-lp .rgrid .rcard:not(:last-child){ border-right:1px solid var(--line); }
.hb-ai-lp .rgrid .rcard:first-child{ padding-left:0; }
.hb-ai-lp .rcard .rn{ font-family:'Outfit',sans-serif; font-weight:800; font-size:40px; color:var(--navy); line-height:1; margin-bottom:18px; }
.hb-ai-lp .rcard h3{ font-size:21px; font-weight:900; line-height:1.5; margin-bottom:15px; letter-spacing:.02em; }
.hb-ai-lp .rcard p{ font-size:14.5px; color:var(--ink-sub); line-height:1.9; }
.hb-ai-lp .works{ background:var(--paper); }
.hb-ai-lp .works-toggle{ display:inline-flex; align-items:center; gap:12px; font-family:inherit; font-weight:700; font-size:15px;
  color:var(--navy); background:#fff; border:1.5px solid var(--navy); border-radius:var(--radius); padding:15px 28px; cursor:pointer; transition:background .2s,color .2s; }
.hb-ai-lp .works-toggle:hover{ background:var(--navy); color:#fff; }
.hb-ai-lp .works-toggle .wt-ico{ font-size:18px; line-height:1; transition:transform .25s; }
.hb-ai-lp .works-toggle[aria-expanded="true"] .wt-ico{ transform:rotate(45deg); }
.hb-ai-lp .works-body[hidden]{ display:none; }
.hb-ai-lp .works-body{ margin-top:10px; }
.hb-ai-lp .bagrid{ display:flex; flex-direction:column; border-top:1px solid var(--rule); }
.hb-ai-lp .barow{ display:grid; grid-template-columns:200px 1fr; gap:32px; padding:34px 0; border-bottom:1px solid var(--line); align-items:center; }
.hb-ai-lp .barow .balabel{ font-weight:900; font-size:17px; line-height:1.6; }
.hb-ai-lp .barow .balabel span{ display:block; font-family:'Outfit',sans-serif; font-size:12px; color:var(--navy); font-weight:700; letter-spacing:.08em; margin-bottom:8px; }
.hb-ai-lp .bapair{ display:grid; grid-template-columns:1fr 56px 1fr; align-items:center; }
.hb-ai-lp .baimg{ aspect-ratio:16/10; border:1px solid var(--line); background:var(--paper-2); display:flex;
  align-items:center; justify-content:center; flex-direction:column; gap:6px; color:#9a9aa6; font-size:12px; text-align:center; padding:12px; }
.hb-ai-lp .baimg .tag{ font-family:'Outfit',sans-serif; font-weight:700; letter-spacing:.1em; font-size:11px; }
.hb-ai-lp .baimg.after{ border-color:var(--navy); }
.hb-ai-lp .baarrow{ text-align:center; color:var(--navy); font-size:24px; font-weight:700; }
.hb-ai-lp .menu{ background:var(--paper-2); }
.hb-ai-lp .mgrid{ display:grid; grid-template-columns:repeat(2,1fr); border-top:1px solid var(--rule); border-left:1px solid var(--line); }
.hb-ai-lp .mcard{ padding:38px 36px; border-bottom:1px solid var(--line); border-right:1px solid var(--line); background:#fff; display:flex; flex-direction:column; }
.hb-ai-lp .mcard .mtag{ align-self:flex-start; font-size:12px; font-weight:700; color:var(--navy);
  border:1px solid var(--navy); border-radius:999px; padding:5px 14px; margin-bottom:18px; }
.hb-ai-lp .mcard h3{ font-size:22px; font-weight:900; letter-spacing:.02em; margin-bottom:14px; }
.hb-ai-lp .mcard p{ font-size:14.5px; color:var(--ink-sub); line-height:1.9; margin-bottom:22px; flex:1; }
.hb-ai-lp .mcard .mcta{ font-weight:700; font-size:14px; color:var(--navy); display:inline-flex; align-items:center; gap:8px;
  border-bottom:1.5px solid var(--navy); padding-bottom:3px; align-self:flex-start; transition:gap .2s; }
.hb-ai-lp .mcard .mcta:hover{ gap:14px; }
.hb-ai-lp .more-head{ margin-top:68px; margin-bottom:34px; display:flex; align-items:baseline; gap:18px; flex-wrap:wrap;
  padding-top:34px; border-top:1px solid var(--line); }
.hb-ai-lp .more-head .en{ font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(20px,2.6vw,30px); color:var(--navy); letter-spacing:.02em; }
.hb-ai-lp .more-head .ja{ font-size:13.5px; color:var(--ink-sub); }
.hb-ai-lp .pgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.hb-ai-lp .pcard{ background:#fff; border:1px solid var(--line); display:flex; flex-direction:column; }
.hb-ai-lp .pcard .pbadge{ align-self:flex-start; font-size:11px; font-weight:700; padding:6px 14px; border-radius:999px; letter-spacing:.02em; margin-bottom:18px; }
.hb-ai-lp .pcard .pbadge.b-vip{ background:#6B2230; color:#fff; }
.hb-ai-lp .pcard .pbadge.b-light{ background:var(--paper-2); color:var(--ink); border:1px solid var(--line); }
.hb-ai-lp .pbody{ padding:30px 26px 28px; display:flex; flex-direction:column; flex:1; }
.hb-ai-lp .pbody .pcat{ font-family:'Outfit',sans-serif; font-weight:700; font-size:12px; letter-spacing:.14em; color:var(--navy); margin-bottom:14px; }
.hb-ai-lp .pbody h3{ font-size:20px; font-weight:900; line-height:1.5; margin-bottom:14px; letter-spacing:.02em; }
.hb-ai-lp .pbody p{ font-size:14px; color:var(--ink-sub); line-height:1.85; margin-bottom:20px; flex:1; }
.hb-ai-lp .pbody .pfoot{ border-top:1px solid var(--line); padding-top:18px; }
.hb-ai-lp .pbody .pprice .punit{ font-size:12px; color:var(--ink-sub); margin-bottom:6px; }
.hb-ai-lp .pbody .pprice .pval{ font-family:'Outfit',sans-serif; font-weight:800; font-size:28px; color:var(--ink); line-height:1; }
.hb-ai-lp .pbody .pprice .pval .y{ font-size:.62em; margin-right:1px; }
.hb-ai-lp .pbody .pprice .pval .tilde{ font-size:.62em; }
.hb-ai-lp .more-link{ margin-top:36px; text-align:right; font-family:'Outfit',sans-serif; font-weight:700;
  font-size:15px; letter-spacing:.04em; color:var(--navy); }
.hb-ai-lp .plan{ background:var(--paper); }
.hb-ai-lp .team{ background:var(--paper-2); }
.hb-ai-lp .tgrid{ display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--rule); margin-top:8px; }
.hb-ai-lp .tcard{ padding:36px 28px; border-bottom:1px solid var(--line); }
.hb-ai-lp .tgrid .tcard:not(:last-child){ border-right:1px solid var(--line); }
.hb-ai-lp .tgrid .tcard:first-child{ padding-left:0; }
.hb-ai-lp .tcard .ava{ width:72px; height:72px; border-radius:50%; border:1px solid var(--line); background:var(--paper-2);
  display:flex; align-items:center; justify-content:center; font-size:10px; color:#aaa; margin-bottom:20px; }
.hb-ai-lp .tcard .tname{ font-size:17px; font-weight:900; margin-bottom:4px; }
.hb-ai-lp .tcard .trole{ font-size:13px; color:var(--navy); font-weight:700; margin-bottom:14px; }
.hb-ai-lp .tcard .tmeta{ font-size:13px; color:var(--ink-sub); line-height:1.8; }
.hb-ai-lp .tgrid.cols-2{ grid-template-columns:repeat(2,1fr); }
.hb-ai-lp .tcard .tlink{ display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:13px; font-weight:700;
  color:var(--navy); border-bottom:1.5px solid var(--navy); padding-bottom:2px; transition:gap .2s; }
.hb-ai-lp .tcard .tlink:hover{ gap:12px; }
.hb-ai-lp .flow{ background:var(--paper); }
.hb-ai-lp .fgrid{ display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--rule); }
.hb-ai-lp .fcard{ padding:40px 24px; border-bottom:1px solid var(--line); }
.hb-ai-lp .fgrid .fcard:not(:last-child){ border-right:1px solid var(--line); }
.hb-ai-lp .fgrid .fcard:first-child{ padding-left:0; }
.hb-ai-lp .fcard .fstep{ font-family:'Outfit',sans-serif; font-weight:700; font-size:13px; color:var(--navy); letter-spacing:.06em; margin-bottom:14px; }
.hb-ai-lp .fcard .fnum{ font-family:'Outfit',sans-serif; font-weight:800; font-size:30px; color:var(--navy); line-height:1; margin-bottom:18px; }
.hb-ai-lp .fcard h3{ font-size:16px; font-weight:900; margin-bottom:12px; line-height:1.5; }
.hb-ai-lp .fcard p{ font-size:13.5px; color:var(--ink-sub); line-height:1.8; }
.hb-ai-lp .results{ background:var(--paper); }
.hb-ai-lp .logorow{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom:40px; }
.hb-ai-lp .logo-ph{ height:54px; min-width:130px; flex:1; border:1px solid var(--line); border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center; font-size:11px; color:#9a9aa6; background:var(--paper-2); }
.hb-ai-lp .resgrid{ display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--rule); margin-bottom:44px; }
.hb-ai-lp .rescell{ padding:40px 24px; border-bottom:1px solid var(--line); }
.hb-ai-lp .resgrid .rescell:not(:last-child){ border-right:1px solid var(--line); }
.hb-ai-lp .resgrid .rescell:first-child{ padding-left:0; }
.hb-ai-lp .rescell .big{ font-family:'Outfit',sans-serif; font-weight:800; font-size:clamp(40px,6vw,66px); color:var(--navy); line-height:1; }
.hb-ai-lp .rescell .big .unit{ font-size:.34em; margin-left:5px; font-weight:700; }
.hb-ai-lp .rescell .label{ margin-top:16px; font-size:14px; color:var(--ink-sub); }
.hb-ai-lp .voice{ border-left:4px solid var(--navy); padding:6px 0 6px 28px; max-width:50em; }
.hb-ai-lp .voice .q{ font-size:17px; font-weight:700; line-height:1.85; margin-bottom:12px; }
.hb-ai-lp .voice .who{ font-size:13.5px; color:var(--ink-sub); }
.hb-ai-lp .ph-note{ margin-top:24px; font-size:12.5px; color:#9a9aa6; }
.hb-ai-lp .founder{ background:var(--navy-dark); color:#fff; }
.hb-ai-lp .founder .eyebrow{ color:var(--bluegray); }
.hb-ai-lp .founder .eyebrow::after{ background:var(--bluegray); }
.hb-ai-lp .founder .fwrap{ display:grid; grid-template-columns:260px 1fr; gap:48px; align-items:center; }
.hb-ai-lp .founder .fwrap.noimg{ display:block; max-width:760px; }
.hb-ai-lp .founder .photo{ aspect-ratio:1/1; border:1px solid rgba(255,255,255,.3); border-radius:4px;
  display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); font-size:12px; }
.hb-ai-lp .founder h2{ font-size:clamp(22px,3.2vw,33px); font-weight:900; line-height:1.5; margin-bottom:22px; letter-spacing:.02em; color:#fff; }
.hb-ai-lp .founder p{ color:rgba(255,255,255,.82); font-size:15.5px; line-height:2.05; max-width:40em; margin-bottom:16px; }
.hb-ai-lp .founder .pname{ color:#fff; font-weight:700; font-size:15px; margin-bottom:22px; }
.hb-ai-lp .founder .links{ display:flex; gap:14px; flex-wrap:wrap; }
.hb-ai-lp .founder .links a{ font-size:13.5px; font-weight:700; color:#fff; border:1.5px solid rgba(255,255,255,.5);
  border-radius:var(--radius); padding:11px 22px; transition:.2s; }
.hb-ai-lp .founder .links a:hover{ background:#fff; color:var(--navy); }
.hb-ai-lp .founder .links a.is-pending{ opacity:.5; cursor:not-allowed; pointer-events:none; }
.hb-ai-lp .faq{ background:var(--paper-2); }
.hb-ai-lp .faqlist{ max-width:840px; border-top:1px solid var(--rule); }
.hb-ai-lp .qa{ border-bottom:1px solid var(--line); }
.hb-ai-lp .qa .q{ display:flex; align-items:center; gap:16px; width:100%; text-align:left; padding:25px 4px;
  background:none; border:0; cursor:pointer; font-size:16px; font-weight:700; color:var(--ink); font-family:inherit; letter-spacing:.02em; }
.hb-ai-lp .qa .q .qmark{ color:var(--navy); font-family:'Outfit',sans-serif; font-weight:800; flex-shrink:0; }
.hb-ai-lp .qa .q .ico{ margin-left:auto; flex-shrink:0; transition:transform .25s; color:var(--navy); font-size:22px; font-weight:400; }
.hb-ai-lp .qa.open .q .ico{ transform:rotate(45deg); }
.hb-ai-lp .qa .a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.hb-ai-lp .qa .a .inner-a{ padding:0 4px 26px 40px; font-size:14.5px; color:var(--ink-sub); line-height:1.95; }
.hb-ai-lp .finalcta{ background:var(--navy); color:#fff; }
.hb-ai-lp .finalcta .eyebrow{ color:var(--bluegray); }
.hb-ai-lp .finalcta .eyebrow::after{ background:var(--bluegray); }
.hb-ai-lp .finalcta h2{ font-size:clamp(25px,4vw,44px); font-weight:900; line-height:1.5; letter-spacing:.02em; margin-bottom:22px; max-width:18em; color:#fff; }
.hb-ai-lp .finalcta p{ color:rgba(255,255,255,.85); font-size:16px; margin-bottom:38px; max-width:34em; line-height:2.05; }
.hb-ai-lp .finalcta .cta-row{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; }
.hb-ai-lp .finalcta .micro{ color:rgba(255,255,255,.62); }
.hb-ai-lp .reveal{ opacity:0; transform:translateY(14px); transition:opacity .8s ease,transform .8s ease; }
.hb-ai-lp .reveal.is-in{ opacity:1; transform:none; }
@media(max-width:900px){
  .hb-ai-lp .rgrid,.hb-ai-lp .tgrid,.hb-ai-lp .tgrid.cols-2,.hb-ai-lp .mgrid,.hb-ai-lp .resgrid,.hb-ai-lp .pgrid{ grid-template-columns:1fr; }
  .hb-ai-lp .rgrid .rcard,.hb-ai-lp .tgrid .tcard,.hb-ai-lp .resgrid .rescell{ border-right:none !important; padding-left:0 !important; padding-right:0 !important; }
  .hb-ai-lp .mgrid{ border-left:none; }
  .hb-ai-lp .fgrid{ grid-template-columns:repeat(2,1fr); }
  .hb-ai-lp .fgrid .fcard{ padding-left:22px; padding-right:22px; }
  .hb-ai-lp .fgrid .fcard:first-child{ padding-left:0; }
  .hb-ai-lp .fgrid .fcard:nth-child(2n){ border-right:none; }
  .hb-ai-lp .barow{ grid-template-columns:1fr; gap:18px; }
  .hb-ai-lp .founder .fwrap{ grid-template-columns:1fr; gap:28px; }
  .hb-ai-lp .founder .photo{ max-width:220px; }
}
@media(max-width:520px){
  .hb-ai-lp .bapair{ grid-template-columns:1fr; gap:10px; }
  .hb-ai-lp .baarrow{ transform:rotate(90deg); }
  .hb-ai-lp .hero .cta-row .btn,.hb-ai-lp .finalcta .cta-row .btn{ width:100%; }
}

/* === プレビュー用：既存サイト heartandbrain.co.jp の公式ヘッダー/フッターを忠実に再現 ===
   （本番 WordPress では get_header()/get_footer() が出力する実物に置き換わる。
     色・構造は公式の header.css / footer.css / common.css を参照して再現） */

/* ---- 公式ヘッダー再現（header.css 準拠） ---- */
