/* ===== yoriva LP 共通スタイル ===== */
:root{
  --bg:#F4F7FB;--bg-2:#FFFFFF;--ink:#16243D;--ink-soft:#46566E;--ink-faint:#8893A4;
  --blue:#2E5A8F;--blue-soft:#5E84AE;--blue-deep:#12243F;
  --gold:#2E7CD6;/* アクセント=鮮やかブルー（旧goldを置換） */--sky:#7FB4E4;/* 暗背景上のアクセント青 */
  --line:rgba(22,36,61,.13);--line-soft:rgba(22,36,61,.07);
  --font:'Noto Sans JP',sans-serif;
  --maxw:1080px;
  /* タイプスケール（Web標準: 本文16px基準 / 日本語行間1.8） */
  --fs-legal:13px;   /* 下限。著作権・fine print（これ以下は使わない） */
  --fs-label:14px;   /* 可読の下限。キャプション・注記・補助ラベル */
  --fs-ui:14px;      /* ナビ・補助テキスト・UI */
  --fs-body:16px;    /* 本文（標準の読みサイズ） */
  --fs-lead:18px;    /* リード・カード見出し */
  --fs-title:20px;   /* やや大きい見出し・カードタイトル */
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:var(--fs-body);line-height:1.8;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
::selection{background:var(--blue);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
section{position:relative;padding:clamp(70px,10vw,120px) 0}

.seclabel{display:flex;align-items:center;gap:14px;font-size:15px;letter-spacing:.16em;
  font-weight:700;text-transform:uppercase;color:var(--ink-faint);margin-bottom:30px}
.seclabel .no{color:var(--gold)}
.seclabel .bar{width:26px;height:1px;background:var(--gold)}
h2{font-weight:900;line-height:1.5;font-size:clamp(26px,4vw,38px);letter-spacing:.01em}
h2 .em{color:var(--blue)}
h2 .gold{color:var(--gold)}
.lead{color:var(--ink-soft);font-size:clamp(16px,1.6vw,18px);max-width:42em;margin-top:24px}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(244,247,251,.85);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
header.nav.scrolled{border-color:var(--line);box-shadow:0 1px 22px -8px rgba(22,36,61,.16)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:flex-start;gap:3px;font-size:23px;font-weight:900;letter-spacing:.02em;color:var(--ink)}
.brand .dot{width:6px;height:6px;border-radius:50%;background:var(--gold);margin-top:6px}
.brandbar{display:flex;align-items:center;gap:12px}
.brand-tag{font-size:var(--fs-label);font-weight:500;color:var(--ink-soft);letter-spacing:.01em;padding-left:12px;border-left:1px solid var(--line);white-space:nowrap}
@media(max-width:680px){.brand-tag{display:none}}
.navlinks{display:flex;align-items:center;gap:28px}
.navlinks a{font-size:var(--fs-ui);font-weight:500;color:var(--ink-soft);transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--blue)}
.btn{font-weight:700;font-size:15px;display:inline-flex;align-items:center;gap:10px;padding:13px 26px;border-radius:3px;
  cursor:pointer;border:1px solid var(--blue);transition:transform .2s,background .2s,color .2s,box-shadow .2s;white-space:nowrap}
.btn .arw{transition:transform .25s}.btn:hover .arw{transform:translateX(4px)}
.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 12px 26px -14px rgba(46,90,143,.8)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.nav .btn{padding:11px 20px}
.nav .btn-primary{color:#fff}
@media(max-width:820px){.navlinks a:not(.btn){display:none}}

/* hero (top) */
.hero{padding-top:clamp(48px,7vw,84px);padding-bottom:clamp(56px,8vw,96px);background:linear-gradient(180deg,#EAF1FB,var(--bg) 58%)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(36px,5vw,64px);align-items:center}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;gap:42px}}
.eyebrow{font-size:16px;letter-spacing:.04em;color:var(--blue);font-weight:700;margin-bottom:24px;display:flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--gold)}
h1{font-weight:900;font-size:clamp(34px,5vw,52px);line-height:1.34;letter-spacing:.01em}
h1 .ruby{color:var(--gold)}
.hero p.sub{margin-top:28px;font-size:clamp(16px,1.7vw,18px);color:var(--ink-soft);max-width:30em}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.hero-note{margin-top:18px;font-size:var(--fs-label);color:var(--ink-faint)}

/* page header (下層ページ) */
.pagehead{padding:clamp(52px,8vw,92px) 0 clamp(30px,5vw,52px)}
.pagehead .eyebrow{margin-bottom:20px}
.pagehead h1{font-size:clamp(30px,4.6vw,44px);line-height:1.4}
.pagehead p{margin-top:22px;color:var(--ink-soft);font-size:clamp(16px,1.6vw,18px);max-width:40em}

/* image placeholder */
.imgph{position:relative;width:100%;border:1px dashed rgba(46,90,143,.38);border-radius:4px;
  background:linear-gradient(135deg,#EAF0F8,#F4F7FB);display:flex;align-items:center;justify-content:center;overflow:hidden}
.imgph::after{content:"";position:absolute;inset:0;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='104' viewBox='0 0 60 104'%3E%3Cg fill='none' stroke='%232E5A8F' stroke-width='1'%3E%3Cpath d='M30 0v52M0 26l30 26 30-26M0 78l30-26 30 26M30 52v52M0 26v52M60 26v52'/%3E%3C/g%3E%3C/svg%3E");background-size:40px}
.imgph .lbl{position:relative;text-align:center;color:var(--blue);font-size:var(--fs-label);line-height:1.8;padding:22px;z-index:1}
.imgph .lbl b{display:block;font-size:var(--fs-ui);font-weight:700;margin-bottom:6px;color:var(--ink)}
.imgph .lbl span{color:var(--ink-faint)}
.imgph .ico{width:30px;height:30px;margin:0 auto 12px;opacity:.5;color:var(--blue)}
.hero-visual{aspect-ratio:4/5;box-shadow:0 30px 60px -34px rgba(18,36,63,.45)}
.ph-img{display:block;width:100%;height:100%;object-fit:cover;border-radius:4px}

/* stat band */
.band{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,56px);padding-top:50px;padding-bottom:50px}
.stat{padding-left:22px;position:relative}
.stat::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;background:var(--gold)}
.stat .big{font-weight:900;font-size:clamp(32px,4.4vw,46px);color:var(--ink);line-height:1.1}
.stat .big em{font-style:normal;font-size:.5em;color:var(--blue);font-weight:700}
.stat .big .to{color:var(--gold);font-size:.7em;margin:0 4px}
.stat .lbl{font-size:var(--fs-label);font-weight:700;color:var(--blue);letter-spacing:.04em;margin-bottom:10px}
.stat .cap{margin-top:12px;font-size:var(--fs-ui);color:var(--ink-soft)}
@media(max-width:680px){.band .wrap{grid-template-columns:1fr;gap:28px}}

/* dark section base */
.dark{background:var(--blue-deep);color:var(--bg);overflow:hidden}
.dark::before{content:"";position:absolute;inset:0;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='104' viewBox='0 0 60 104'%3E%3Cg fill='none' stroke='%232E7CD6' stroke-width='1'%3E%3Cpath d='M30 0v52M0 26l30 26 30-26M0 78l30-26 30 26M30 52v52M0 26v52M60 26v52'/%3E%3C/g%3E%3C/svg%3E");background-size:46px}
.dark .wrap{position:relative}
.dark .seclabel{color:rgba(244,247,251,.5)}
.dark h2{color:var(--bg)}
.dark .lead{color:rgba(244,247,251,.8)}

/* problem list */
.plist{margin-top:46px;display:flex;flex-direction:column}
.pitem{display:flex;gap:22px;padding:22px 0;border-bottom:1px solid rgba(244,247,251,.14);align-items:baseline}
.pitem:first-child{border-top:1px solid rgba(244,247,251,.14)}
.pitem .pn{color:var(--gold);font-size:var(--fs-ui);font-weight:700;flex:0 0 auto;width:28px}
.pitem p{color:rgba(244,247,251,.84);font-size:var(--fs-body)}
.pclose{margin-top:44px;font-weight:700;font-size:clamp(19px,2.6vw,26px);color:var(--bg);line-height:1.7}
.pclose .em{color:var(--gold)}

/* before / after */
.ba{margin-top:50px;display:grid;grid-template-columns:1fr auto 1fr;gap:0 clamp(16px,3vw,40px);align-items:stretch}
@media(max-width:760px){.ba{grid-template-columns:1fr}}
.ba-col{padding:32px clamp(20px,3vw,32px);border-radius:6px}
.ba-before{background:#EDEFF3;border:1px solid var(--line)}
.ba-after{background:var(--bg-2);border:1px solid var(--blue);box-shadow:0 24px 50px -30px rgba(46,90,143,.5)}
.ba-col .h{font-size:var(--fs-label);letter-spacing:.14em;font-weight:700;text-transform:uppercase;margin-bottom:22px;display:flex;align-items:center;gap:10px}
.ba-before .h{color:var(--ink-faint)}
.ba-after .h{color:var(--blue)}
.ba-after .h::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold)}
.ba-row{padding:14px 0;border-bottom:1px dashed var(--line)}
.ba-row:last-child{border-bottom:none}
.ba-row .t{font-size:var(--fs-label);color:var(--ink-faint);margin-bottom:3px}
.ba-before .ba-row .v{font-size:var(--fs-body);color:var(--ink-soft)}
.ba-after .ba-row .v{font-size:var(--fs-body);color:var(--ink);font-weight:700}
.ba-after .ba-row .v b{color:var(--blue)}
.ba-arrow{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:26px;font-weight:700}
@media(max-width:760px){.ba-arrow{padding:10px 0;transform:rotate(90deg)}}

/* 仕組み図解 */
.figwrap{margin-top:clamp(56px,8vw,92px)}
.fightitle{font-weight:700;font-size:clamp(18px,2vw,20px);margin-bottom:8px}
.figsub{font-size:var(--fs-ui);color:var(--ink-soft);margin-bottom:36px}
.flowfig{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:0 clamp(8px,1.6vw,20px);align-items:stretch}
@media(max-width:760px){.flowfig{grid-template-columns:1fr}}
.fstep{background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:28px 24px;text-align:center}
.fstep .sn{font-size:var(--fs-legal);letter-spacing:.12em;font-weight:700;color:var(--gold);margin-bottom:16px}
.fstep .fic{width:42px;height:42px;margin:0 auto 16px;color:var(--blue)}
.fstep .fic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.4}
.fstep h4{font-weight:700;font-size:var(--fs-lead);margin-bottom:8px}
.fstep p{font-size:var(--fs-ui);color:var(--ink-soft);line-height:1.8}
.fstep.hl{border-color:var(--blue);background:#F0F5FB}
.farrow{display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:24px;font-weight:700}
@media(max-width:760px){.farrow{padding:12px 0;transform:rotate(90deg)}}
.fignote{margin-top:24px;font-size:var(--fs-label);color:var(--ink-faint);text-align:center}
.fignote b{color:var(--blue);font-weight:700}

/* services（詳細） */
.svc-grid{margin-top:54px;display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,52px) clamp(36px,5vw,68px)}
@media(max-width:760px){.svc-grid{grid-template-columns:1fr;gap:44px}}
.svc{padding-top:28px;border-top:1px solid var(--line);transition:border-color .3s}
.svc:hover{border-color:var(--blue)}
.svc .ic{width:42px;height:42px;color:var(--blue);margin-bottom:22px}
.svc .ic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.4}
.svc .res{font-size:var(--fs-label);color:var(--gold);font-weight:700;margin-bottom:10px}
.svc h3{font-weight:700;font-size:var(--fs-title);margin-bottom:12px}
.svc p{font-size:var(--fs-body);color:var(--ink-soft)}

/* services概要（トップ用ミニ） */
.mini-grid{margin-top:50px;display:grid;grid-template-columns:1fr 1fr;gap:0}
@media(max-width:680px){.mini-grid{grid-template-columns:1fr}}
.mini{display:flex;gap:18px;padding:26px 24px;border-top:1px solid var(--line)}
.mini:nth-child(odd){border-right:1px solid var(--line)}
@media(max-width:680px){.mini:nth-child(odd){border-right:none}}
.mini .mic{width:34px;height:34px;color:var(--blue);flex:0 0 auto}
.mini .mic svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.4}
.mini h3{font-weight:700;font-size:var(--fs-lead);margin-bottom:4px}
.mini p{font-size:var(--fs-ui);color:var(--ink-soft);line-height:1.75}

/* mid cta */
.midcta{background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.midcta .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding-top:46px;padding-bottom:46px}
.midcta .t{font-weight:700;font-size:clamp(19px,2.2vw,24px);line-height:1.6}
.midcta .t small{display:block;font-size:var(--fs-ui);color:var(--ink-soft);margin-top:8px;font-weight:400}

/* flow / pricing (dark) */
.steps{margin-top:50px;display:grid;grid-template-columns:repeat(4,1fr);border:1px solid rgba(244,247,251,.18);border-radius:5px;overflow:hidden}
.step{padding:32px 26px;border-right:1px solid rgba(244,247,251,.18)}
.step:last-child{border-right:none}
.step .sn{font-size:var(--fs-legal);color:var(--sky);letter-spacing:.12em;font-weight:700;margin-bottom:18px}
.step h4{font-weight:700;font-size:var(--fs-lead);margin-bottom:14px;color:var(--bg)}
.step .price{font-weight:900;font-size:clamp(23px,3vw,30px);color:var(--bg);line-height:1.15}
.step .price small{display:block;font-size:var(--fs-label);color:rgba(244,247,251,.7);font-weight:400;margin-top:5px}
.step .price .free{color:var(--sky)}
.step .desc{margin-top:16px;font-size:var(--fs-ui);color:rgba(244,247,251,.72)}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr}.step:nth-child(2n){border-right:none}.step:nth-child(-n+2){border-bottom:1px solid rgba(244,247,251,.18)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}.step{border-right:none;border-bottom:1px solid rgba(244,247,251,.18)}.step:last-child{border-bottom:none}}
.flownote{margin-top:26px;font-size:var(--fs-label);color:rgba(244,247,251,.72)}
.flownote::before{content:"※ ";color:var(--gold);font-weight:700}

/* principles */
.prin-grid{margin-top:54px;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(30px,4vw,52px)}
@media(max-width:760px){.prin-grid{grid-template-columns:1fr;gap:38px}}
.prin .pk{color:var(--gold);font-size:22px;font-weight:900;margin-bottom:18px}
.prin h4{font-weight:700;font-size:var(--fs-lead);margin-bottom:12px;line-height:1.55}
.prin p{font-size:var(--fs-body);color:var(--ink-soft)}

/* faq */
.fq{margin-top:46px;border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:24px 44px 24px 0;position:relative;font-weight:700;
  font-size:clamp(16px,1.6vw,18px);color:var(--ink);transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--blue)}
.faq summary .q{color:var(--gold);margin-right:12px;font-weight:900}
.faq summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:24px;color:var(--blue);font-weight:300;transition:transform .3s}
.faq details[open] summary::after{content:"−"}
.faq .ans{padding:0 44px 28px 0;color:var(--ink-soft);font-size:var(--fs-body);line-height:1.9}
.faq .ans .a{color:var(--blue);margin-right:12px;font-weight:900}

/* profile */
.profile .pgrid{display:grid;grid-template-columns:.78fr 1.22fr;gap:clamp(40px,6vw,76px);align-items:start}
@media(max-width:820px){.profile .pgrid{grid-template-columns:1fr;gap:42px}}
.profile-visual{aspect-ratio:4/5}
.seal{width:88px;height:88px;border-radius:50%;border:2px solid var(--blue);display:flex;align-items:center;justify-content:center;
  font-size:38px;font-weight:900;color:var(--blue);margin-bottom:28px;position:relative}
.seal .dot{position:absolute;top:13px;right:15px;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.profile h2{margin-bottom:6px}
.profile .who{font-size:var(--fs-label);letter-spacing:.14em;font-weight:700;color:var(--ink-faint);text-transform:uppercase;margin-bottom:26px}
.profile p{color:var(--ink-soft);font-size:var(--fs-body);margin-bottom:20px}
.profile p strong{color:var(--ink);font-weight:700}
.creed{margin-top:30px;display:flex;flex-direction:column;gap:13px}
.creed div{display:flex;gap:14px;align-items:baseline;font-weight:700;font-size:var(--fs-body);color:var(--ink)}
.creed div::before{content:"—";color:var(--gold)}

/* 会社概要テーブル */
.bizinfo{margin-top:8px;border-top:1px solid var(--line)}
.bizinfo .row{display:grid;grid-template-columns:160px 1fr;gap:0 24px;padding:18px 0;border-bottom:1px solid var(--line)}
@media(max-width:560px){.bizinfo .row{grid-template-columns:1fr;gap:4px;padding:16px 0}}
.bizinfo dt{font-size:var(--fs-ui);font-weight:700;color:var(--ink-faint)}
.bizinfo dd{font-size:var(--fs-body);color:var(--ink)}

/* お申し込み後の流れ（縦タイムライン） */
.timeline{margin-top:50px;display:flex;flex-direction:column}
.tl-item{display:grid;grid-template-columns:170px 1fr;gap:0 28px;padding:0 0 36px;position:relative}
.tl-item:last-child{padding-bottom:0}
.tl-when{font-size:var(--fs-ui);font-weight:700;color:var(--blue);padding-top:2px}
.tl-body{position:relative;padding-left:34px;padding-bottom:6px}
.tl-body::before{content:"";position:absolute;left:9px;top:6px;bottom:-30px;width:2px;background:var(--line)}
.tl-item:last-child .tl-body::before{display:none}
.tl-body::after{content:"";position:absolute;left:3px;top:5px;width:15px;height:15px;border-radius:50%;background:var(--bg-2);border:3px solid var(--blue)}
.tl-step{font-size:var(--fs-legal);letter-spacing:.12em;font-weight:700;color:var(--gold);margin-bottom:4px}
.tl-body h4{font-weight:700;font-size:var(--fs-lead);margin-bottom:6px}
.tl-body p{font-size:var(--fs-body);color:var(--ink-soft)}
@media(max-width:560px){.tl-item{grid-template-columns:1fr;gap:6px}.tl-when{padding-left:34px}.tl-body::before{top:30px}}

/* 料金プラン（構築2プラン＋保守） */
.plans{margin-top:50px;display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,30px)}
@media(max-width:680px){.plans{grid-template-columns:1fr}}
.plan{position:relative;background:rgba(244,247,251,.05);border:1px solid rgba(244,247,251,.2);border-radius:6px;padding:34px 30px}
.plan.feat{border-color:var(--sky);box-shadow:0 24px 50px -30px rgba(127,180,228,.5)}
.plan .badge{position:absolute;top:-12px;left:30px;background:var(--sky);color:var(--blue-deep);font-size:var(--fs-legal);font-weight:700;padding:4px 12px;border-radius:3px}
.plan .pname{font-weight:700;font-size:var(--fs-lead);color:var(--bg);margin-bottom:10px}
.plan .pprice{font-weight:900;font-size:clamp(26px,3.4vw,34px);color:var(--bg);line-height:1.15}
.plan .pprice small{font-size:var(--fs-label);font-weight:400;color:rgba(244,247,251,.7);margin-left:4px}
.plan .pdesc{margin-top:16px;font-size:var(--fs-ui);color:rgba(244,247,251,.78);line-height:1.85}
.plan-sub{margin-top:24px;background:rgba(244,247,251,.04);border:1px dashed rgba(244,247,251,.22);border-radius:6px;
  padding:22px 26px;display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 16px}
.plan-sub .pname{font-weight:700;font-size:var(--fs-body);color:var(--bg)}
.plan-sub .pprice{font-weight:900;font-size:var(--fs-title);color:var(--bg)}
.plan-sub .pprice small{font-size:var(--fs-label);font-weight:400;color:rgba(244,247,251,.7);margin-left:4px}
.plan-sub .pdesc{flex:1 1 240px;font-size:var(--fs-ui);color:rgba(244,247,251,.78)}

/* contact */
.cwrap{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:end}
@media(max-width:760px){.cwrap{grid-template-columns:1fr;gap:36px}}
.ccard{background:rgba(244,247,251,.05);border:1px solid rgba(244,247,251,.18);border-radius:5px;padding:36px}
.ccard .who{font-weight:700;font-size:var(--fs-title);margin-bottom:6px;color:var(--bg)}
.ccard .role{font-size:var(--fs-label);color:rgba(244,247,251,.6);margin-bottom:26px}
.ccard .mail{font-size:clamp(17px,2vw,20px);font-weight:700;color:var(--gold);word-break:break-all;display:block;margin-bottom:24px}
.ccard .btn-primary{width:100%;justify-content:center;background:var(--gold);border-color:var(--gold);color:var(--blue-deep);box-shadow:none}
.ccard .btn-primary:hover{filter:brightness(1.07)}

/* footer */
footer{background:var(--blue-deep);color:rgba(244,247,251,.58);border-top:1px solid rgba(244,247,251,.13);padding:44px 0}
.fwrap{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:flex-start}
.fbrand{font-size:var(--fs-lead);font-weight:900;color:var(--bg);letter-spacing:.02em;margin-bottom:8px}
.fnote{font-size:var(--fs-label);max-width:32em;line-height:1.7}
.fnav{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:14px}
.fnav a{font-size:var(--fs-label);color:rgba(244,247,251,.72)}
.fnav a:hover{color:var(--gold)}
.fcopy{font-size:var(--fs-legal);letter-spacing:.04em;color:rgba(244,247,251,.5)}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.reveal.vis{opacity:1;transform:none}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
.hero .eyebrow{animation:fadeUp .9s cubic-bezier(.16,1,.3,1) both}
.hero h1{animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .12s both}
.hero p.sub{animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .26s both}
.hero .hero-cta{animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .4s both}
.hero .hero-note{animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .5s both}
.hero .hero-visual{animation:fadeUp 1.1s cubic-bezier(.16,1,.3,1) .35s both}
@media(prefers-reduced-motion:reduce){*{animation:none!important}.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px}

/* ===== form ===== */
.formwrap{max-width:680px}
.notice{background:#FBECEC;border:1px solid #E5B8B8;color:#9A3838;padding:14px 18px;border-radius:5px;font-size:var(--fs-ui);margin-bottom:30px}
.field{margin-bottom:26px}
.field>label{display:block;font-size:var(--fs-ui);font-weight:700;margin-bottom:9px}
.field .opt{font-weight:400;color:var(--ink-faint);font-size:var(--fs-legal);margin-left:8px}
.req{color:var(--blue);font-size:var(--fs-legal);font-weight:700;margin-left:8px;border:1px solid var(--blue);border-radius:3px;padding:1px 6px}
.field input[type=text],.field input[type=email],.field textarea{width:100%;font-family:var(--font);font-size:var(--fs-body);
  padding:13px 15px;border:1px solid var(--line);border-radius:5px;background:var(--bg-2);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field input::placeholder,.field textarea::placeholder{color:#A8B0BC}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(46,90,143,.13)}
.field textarea{min-height:140px;resize:vertical;line-height:1.85}
.field .hint{font-size:var(--fs-label);color:var(--ink-faint);margin-top:8px}
.radios{display:flex;flex-direction:column;gap:12px}
.radio{display:flex;align-items:flex-start;gap:13px;padding:16px 18px;border:1px solid var(--line);border-radius:6px;cursor:pointer;transition:border-color .2s,background .2s}
.radio:hover{border-color:var(--blue-soft)}
.radio input{margin-top:2px;accent-color:var(--blue);width:18px;height:18px;flex:0 0 auto}
.radio:has(input:checked){border-color:var(--blue);background:#F0F5FB}
.radio .rt{display:block;font-weight:700;font-size:var(--fs-body)}
.radio .rd{display:block;font-size:var(--fs-label);color:var(--ink-soft);margin-top:3px}
.hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden}
.submit{margin-top:8px}
.submit button{font-family:var(--font);width:100%;justify-content:center;border:none;cursor:pointer}
.privnote{margin-top:14px;font-size:var(--fs-label);color:var(--ink-faint);line-height:1.7}
.alt-contact{margin-top:26px;font-size:var(--fs-label);color:var(--ink-soft)}
.alt-contact a{color:var(--blue);font-weight:700;text-decoration:underline;text-underline-offset:3px}
.thanks{max-width:620px;text-align:center;margin:0 auto;padding:clamp(40px,8vw,80px) 0}
.thanks .mk{width:64px;height:64px;border-radius:50%;background:#F0F5FB;border:1px solid var(--blue);color:var(--blue);
  display:flex;align-items:center;justify-content:center;margin:0 auto 28px;font-size:30px;font-weight:900}
.thanks h1{font-size:clamp(28px,4vw,38px);margin-bottom:20px}
.thanks p{color:var(--ink-soft);font-size:var(--fs-body);margin-bottom:14px}
