/* =====================================================================
   LuLu AI Academy — v4 "JEC-grounded" design system（ゼロから再構築）
   アートディレクション：
   ・白×黒のモノクロ基調。赤(#D70F2E)の使用は「①ヘッダーCTA/ロゴ ②英語ラベル+罫 ③数字強調」の3箇所のみ
   ・説明会/OC系のCTAだけ山吹(#F5A200)
   ・角丸0／影なし／1px罫線で構成。タイポは大きくジャンプさせる
   ・写真が主役。プレースホルダはグレー枠（対角線）で統一
   ===================================================================== */
:root{
  --red:#1C57C9; --red-d:#143F95;
  --amber:#F5A200; --amber-d:#D88E00;
  --ink:#1A1A1A; --ink2:#555; --ink3:#9A9A9A;
  --line:#E3E3E3; --bg:#FFFFFF; --bg2:#F3F6FA; --tint:#EAF1FB; --tint-line:#D4E2F4;
  --tex:url("img/tex-blue.png");
  --grid-ft:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20width%3D%2726%27%20height%3D%2726%27%3E%3Cpath%20d%3D%27M26%200H0v26%27%20fill%3D%27none%27%20stroke%3D%27%23FFFFFF%27%20stroke-opacity%3D%27.10%27%20stroke-width%3D%271%27/%3E%3C/svg%3E");
  --grid:url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20width%3D%2726%27%20height%3D%2726%27%3E%3Cpath%20d%3D%27M26%200H0v26%27%20fill%3D%27none%27%20stroke%3D%27%239DB1E8%27%20stroke-opacity%3D%27.55%27%20stroke-width%3D%271%27/%3E%3C/svg%3E");
  --w:1180px; --px:clamp(18px,4vw,40px);
  --jp:"Noto Sans JP","Hiragino Kaku Gothic ProN",system-ui,sans-serif;
  --en:"Outfit",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{transition:none!important;animation:none!important}}
body{font-family:var(--jp);color:var(--ink);background:var(--bg);font-size:15px;line-height:1.9;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.w{max-width:var(--w);margin:0 auto;padding:0 var(--px)}
.skip{position:absolute;left:-9999px}.skip:focus{left:8px;top:8px;background:var(--ink);color:#fff;padding:8px 14px;z-index:999}

/* ---------- 細部の共通言語 ---------- */
.en{font-family:var(--en)}
.label{font-family:var(--en);font-weight:700;font-size:10.5px;letter-spacing:.3em;color:#8DA2C4;text-transform:uppercase;margin-top:10px}
.h-row>div{display:flex;flex-direction:column-reverse}
.h-sec{font-weight:900;font-size:clamp(26px,3.4vw,38px);line-height:1.4;letter-spacing:.02em;margin-top:0}
.h-row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:clamp(28px,4vw,48px)}
.more{display:inline-flex;align-items:center;gap:14px;font-weight:700;font-size:13px;letter-spacing:.08em;border:1px solid var(--ink);padding:13px 28px;transition:background .15s,color .15s}
.more::after{content:"→";font-family:var(--en)}
.more:hover{background:var(--ink);color:#fff}
.sec{padding:clamp(64px,9vw,120px) 0}
.sec--gray{background-color:#F7FAFE;background-image:var(--grid)}
.sec--plain{background-color:var(--bg2);background-image:var(--tex);background-repeat:repeat}
.note{font-size:12px;color:var(--ink3);line-height:1.8}

/* ボタン */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-weight:700;font-size:14px;letter-spacing:.08em;padding:16px 30px;border:1px solid transparent;cursor:pointer;transition:opacity .15s}
.btn:hover{opacity:.85}
.btn--red{background:var(--red);color:#fff}
.btn--amber{background:var(--amber);color:#fff}
.btn--ink{background:var(--ink);color:#fff}
.btn--line{background:#fff;color:var(--ink);border-color:var(--ink)}
.btn--lg{font-size:15px;padding:19px 40px}

/* ---------- ユーティリティバー（白・細） ---------- */
.util{border-bottom:1px solid var(--line);font-size:12px}
.util .w{display:flex;justify-content:space-between;align-items:center;min-height:34px;gap:16px}
.util__place{font-weight:700;letter-spacing:.08em;color:var(--ink2)}
.util__place b{color:var(--red);margin-right:8px;font-family:var(--en);letter-spacing:.12em}
.util__links{display:flex;gap:22px;color:var(--ink2)}
.util__links a:hover{color:var(--red)}
@media(max-width:760px){.util__links{display:none}}

/* ---------- ヘッダー ---------- */
.hd{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line)}
.hd__in{max-width:var(--w);margin:0 auto;padding:0 var(--px);display:flex;align-items:center;gap:26px;min-height:76px}
.logo{display:flex;align-items:center;gap:12px}
.logo__mk{width:42px;height:42px;background:var(--red);color:#fff;display:grid;place-items:center;font-family:var(--en);font-weight:700;font-size:16px}
.logo__nm{display:block;white-space:nowrap;font-family:var(--en);font-weight:700;font-size:19px;letter-spacing:.01em;line-height:1.1}
.logo__sb{display:block;white-space:nowrap;font-size:10px;color:var(--ink3);letter-spacing:.14em;margin-top:3px}
.nav{margin-left:auto}
.nav ul{display:flex}
.nav a{display:block;text-align:center;padding:14px 13px;line-height:1.25}
.nav .jp{display:block;font-weight:700;font-size:13.5px;white-space:nowrap}
.nav .e{display:block;font-family:var(--en);font-weight:600;font-size:9px;letter-spacing:.18em;color:var(--ink3);text-transform:uppercase;margin-top:3px}
.nav a:hover .jp,.nav a[aria-current] .jp{color:var(--red)}
.nav a:hover .e,.nav a[aria-current] .e{color:var(--red)}
.hd__cta{display:flex;flex-shrink:0}
.hd__cta a{display:grid;place-items:center;width:104px;min-height:76px;color:#fff;font-weight:700;font-size:13.5px;letter-spacing:.06em;line-height:1.4;text-align:center}
.hd__cta a:first-child{background:var(--red)}
.hd__cta a:last-child{background:var(--amber)}
.hd__cta a:hover{opacity:.88}
.menu{display:none}
@media(max-width:1120px){
  .nav{display:none}
  .menu{display:grid;place-items:center;margin-left:auto;width:48px;height:48px;border:1px solid var(--line);background:#fff;cursor:pointer}
  .menu span{display:block;width:20px;height:2px;background:var(--ink);position:relative}
  .menu span::before,.menu span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink)}
  .menu span::before{top:-6px}.menu span::after{top:6px}
}
@media(max-width:560px){.hd__cta{display:none}.logo__sb{display:none}}

/* ドロワー */
.dw{position:fixed;inset:0;z-index:150;display:none}
.dw.on{display:block}
.dw__bg{position:absolute;inset:0;background:rgba(20,20,20,.5)}
.dw__p{position:absolute;top:0;right:0;width:min(320px,86vw);height:100%;background:#fff;overflow:auto;padding:18px 22px 90px}
.dw__x{margin-left:auto;display:grid;place-items:center;width:44px;height:44px;border:1px solid var(--line);background:#fff;font-size:18px;cursor:pointer}
.dw nav a{display:block;padding:14px 4px;border-bottom:1px solid var(--line);font-weight:700;font-size:15px}
.dw .btn{width:100%;margin-top:12px}

/* PC右端固定タブ */
.fix{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:110;display:grid;gap:4px}
.fix a{display:block;width:48px;padding:18px 16px;color:#fff;font-weight:700;font-size:14px;line-height:1.5;text-align:center;word-break:break-all}
.fix a:first-child{background:var(--red)}
.fix a:last-child{background:var(--amber)}
.fix a:hover{opacity:.88}
@media(max-width:1120px){.fix{display:none}}

/* モバイル下部CTA */
.mcta{display:none}
@media(max-width:760px){
  body{padding-bottom:60px}
  .mcta{display:grid;grid-template-columns:1fr 1fr;position:fixed;left:0;right:0;bottom:0;z-index:120;border-top:1px solid rgba(255,255,255,.3)}
  .mcta a{display:grid;place-items:center;padding:17px 8px;font-weight:700;font-size:14px;color:#fff;letter-spacing:.06em}
  .mcta a:first-child{background:var(--ink)}
  .mcta a:last-child{background:var(--amber)}
}

/* ---------- MV（全幅写真＋キャッチ） ---------- */
.mv{position:relative;background:#000}
.mv__img{width:100%;height:clamp(440px,62vh,660px);object-fit:cover;object-position:72% 30%;opacity:.96}
.mv__cover{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.34) 0%,rgba(0,0,0,.05) 55%,rgba(0,0,0,0) 75%)}
.mv__in{position:absolute;inset:0}
.mv__in .w{height:100%;display:flex;flex-direction:column;justify-content:center}
.mv__tag{display:inline-flex;align-self:flex-start;background:var(--red);color:#fff;font-weight:700;font-size:12.5px;letter-spacing:.14em;padding:7px 16px}
.mv__cp{color:#fff;font-weight:900;font-size:clamp(34px,5.8vw,66px);line-height:1.32;letter-spacing:.03em;margin-top:18px;text-shadow:0 2px 28px rgba(0,0,0,.45)}
.mv__sb{color:#fff;font-weight:700;font-size:clamp(13.5px,1.6vw,16px);letter-spacing:.05em;margin-top:14px;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.mv__btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.mv__credit{position:absolute;right:10px;bottom:8px;color:rgba(255,255,255,.75);font-size:10px;letter-spacing:.06em}
@media(max-width:760px){
  .mv__img{height:64vw;min-height:300px}
  .mv__cover{background:linear-gradient(0deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.06) 55%)}
  .mv__in .w{justify-content:flex-end;padding-bottom:24px}
  .mv__btns{display:none}
}
/* MV下：白の3導線バー（モバイルで復活） */
.mvbar{border-bottom:1px solid var(--line)}
.mvbar .w{display:grid;grid-template-columns:repeat(3,1fr)}
.mvbar a{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px 10px;font-weight:700;font-size:14px;border-left:1px solid var(--line)}
.mvbar a:first-child{border-left:0}
.mvbar a::after{content:"→";font-family:var(--en);color:var(--red)}
.mvbar a:hover{background:var(--bg2)}
@media(max-width:760px){.mvbar .w{grid-template-columns:1fr}.mvbar a{border-left:0;border-top:1px solid var(--line);justify-content:space-between;padding:16px 4px}.mvbar a:first-child{border-top:0}}

/* ---------- NEWS（1行帯） ---------- */
.news{border-bottom:1px solid var(--line)}
.news .w{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;padding-top:14px;padding-bottom:14px}
.news__h{font-family:var(--en);font-weight:700;font-size:13px;letter-spacing:.22em;color:var(--red)}
.news__t{font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.news__t time{font-family:var(--en);color:var(--ink3);margin-right:14px;font-size:12.5px}
.news__all{font-size:12.5px;font-weight:700;white-space:nowrap}
.news__all::after{content:" →";font-family:var(--en);color:var(--red)}
@media(max-width:640px){.news .w{grid-template-columns:auto 1fr}.news__all{display:none}}

/* ---------- 対象者パネル ---------- */
.tg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:760px){.tg{grid-template-columns:1fr}}
.tg a{position:relative;display:block;background:#fff}
.tg img{width:100%;aspect-ratio:3/2;object-fit:cover}
.tg__b{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 20px}
.tg__t{font-weight:900;font-size:17px;line-height:1.4}
.tg__t .num{font-family:var(--en);font-weight:700;font-size:1.55em;color:var(--red);line-height:1;vertical-align:-.06em;margin:0 1px}
.tg__t small{display:block;font-size:12px;font-weight:700;color:var(--ink2);margin-top:4px;letter-spacing:.04em}
.tg__ar{flex-shrink:0;font-family:var(--en);font-weight:700;color:var(--red);font-size:18px;transition:transform .15s}
.tg a:hover .tg__ar{transform:translateX(4px)}
.tg a:hover .tg__t{color:var(--red)}

/* ---------- FIELDS（JEC様式：グレーカード＋カラー塗りアイコン） ---------- */
.fd{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.2vw,26px)}
@media(max-width:880px){.fd{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.fd{grid-template-columns:1fr}}
.fd__c{position:relative;background-color:#EEF1F6;padding:30px 28px 26px;overflow:hidden}
/* 折り紙風コーナー（2色三角） */
.fd__c::before,.fd__c::after{content:"";position:absolute;left:0;top:0;width:0;height:0;border-style:solid}
.fd__c::before{border-width:46px 46px 0 0;border-color:var(--c1,#1C57C9) transparent transparent transparent}
.fd__c::after{border-width:24px 24px 0 0;border-color:var(--c2,#F5A623) transparent transparent transparent;left:22px;top:0;transform:translateX(0)}
.fd__hd{display:flex;align-items:center;justify-content:center;gap:13px;min-height:64px;position:relative;padding:0 42px}
.fd__ic{width:46px;height:46px;flex-shrink:0}
.fd__t{font-weight:900;font-size:18px;line-height:1.35;text-align:center}
.fd__ar{position:absolute;right:0;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--ink);font-family:var(--en);font-weight:700;font-size:15px;box-shadow:0 1px 3px rgba(0,0,0,.08);transition:transform .15s}
a.fd__c{display:block;color:inherit}
a.fd__c:hover .fd__ar{transform:translateY(-50%) translateX(3px)}
.fd__l{margin-top:18px;border-top:1px solid #D9DEE7;padding-top:8px}
.fd__l>a{display:flex;gap:9px;align-items:baseline;flex-wrap:wrap;padding:8px 2px;font-size:13.5px;color:var(--ink2);line-height:1.6}
.fd__l>a::before{content:"›";font-family:var(--en);font-weight:700;color:var(--ink3)}
.fd__l a:hover{color:var(--red)}
.fd__l a:hover::before{color:var(--red)}
.fd__tag{font-size:10.5px;font-weight:700;color:var(--amber-d);border:1px solid var(--amber);padding:1px 8px;margin-left:6px;white-space:nowrap}

/* ---------- ロードマップ（横帯・番号大） ---------- */
.rd{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);background:var(--line);gap:1px}
@media(max-width:880px){.rd{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.rd{grid-template-columns:1fr}}
.rd__c{background:#fff;padding:28px 24px 30px}
.rd__c--goal{background-color:#E9F4F0;background-image:var(--tex);background-repeat:repeat;border-top:3px solid #1E8F77}
.rd__no{font-family:var(--en);font-weight:700;font-size:clamp(34px,3.6vw,46px);line-height:1;color:var(--red)}
.rd__c--goal .rd__no{color:#1E8F77}
.rd__y{font-family:var(--en);font-weight:600;font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink3);margin-top:6px}
.rd__c--goal .rd__y{color:#6FA396}
.rd__t{font-weight:900;font-size:16.5px;line-height:1.5;margin:10px 0 8px}
.rd__x{font-size:12.5px;color:var(--ink2);line-height:1.85}
.rd__c--goal .rd__x{color:var(--ink2)}

/* ---------- 学費・短期コース（情報帯） ---------- */
.price{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,64px);align-items:start}
@media(max-width:840px){.price{grid-template-columns:1fr}}
.price__num{font-family:var(--en);font-weight:700;font-size:clamp(40px,5vw,58px);line-height:1;color:var(--red)}
.price__num small{font-size:.42em;font-weight:700;font-family:var(--jp);color:var(--ink);margin-left:4px}
.quote{border:1px solid var(--line);padding:18px 22px;font-size:13.5px;color:var(--ink2);background:#fff;margin:20px 0}
.quote cite{display:block;font-style:normal;font-size:11.5px;color:var(--ink3);margin-top:8px;word-break:break-all}
.spec{width:100%;border-collapse:collapse;background:#fff;font-size:14px}
.spec th,.spec td{border:1px solid var(--line);padding:13px 16px;text-align:left;vertical-align:top}
.spec th{background:#E2EAF8;font-weight:700;width:34%;white-space:nowrap}
.spec .yen{font-family:var(--en);font-weight:700;white-space:nowrap}

/* 短期コース帯 */
.short{background-color:#EAF1FB;background-image:var(--tex);background-repeat:repeat;border-top:1px solid var(--tint-line);border-bottom:1px solid var(--tint-line)}
.short .w{display:grid;grid-template-columns:1fr auto;gap:clamp(24px,5vw,72px);align-items:center;padding-top:clamp(48px,6vw,80px);padding-bottom:clamp(48px,6vw,80px)}
@media(max-width:840px){.short .w{grid-template-columns:1fr}}
.short__lb{display:inline-flex;background:var(--amber);color:#fff;font-weight:700;font-size:12px;letter-spacing:.14em;padding:6px 14px}
.short__t{font-weight:900;font-size:clamp(24px,3.2vw,34px);margin:16px 0 12px;line-height:1.45}
.short__x{color:var(--ink2);font-size:14px;max-width:38em}
.short__p{font-family:var(--en);font-weight:700;font-size:clamp(48px,6vw,72px);line-height:1;text-align:right;color:var(--red)}
.short__p small{display:block;font-family:var(--jp);font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--ink3);margin-top:10px;text-align:right}
@media(max-width:840px){.short__p,.short__p small{text-align:left}}

/* ---------- VOICE ---------- */
.vc{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:760px){.vc{grid-template-columns:1fr}}
.vc__c{background:#fff;display:grid;grid-template-columns:150px 1fr;gap:0}
@media(max-width:480px){.vc__c{grid-template-columns:1fr}}
.vc__ph{width:100%;height:100%;object-fit:cover;min-height:150px}
.vc__b{padding:24px 26px}
.vc__q{font-weight:900;font-size:16px;line-height:1.6}
.vc__x{font-size:13px;color:var(--ink2);margin-top:10px;line-height:1.9}
.vc__w{font-size:12px;color:var(--ink3);margin-top:12px}
.vc__w b{color:var(--ink);font-size:13px}

/* ---------- 学びの環境（写真2:1帯） ---------- */
.env{display:grid;grid-template-columns:2fr 1fr;gap:clamp(14px,2vw,24px)}
@media(max-width:760px){.env{grid-template-columns:1fr}}
.env figure img{width:100%;aspect-ratio:16/9;object-fit:cover}
.env figure:nth-child(2) img,.env figure:nth-child(3) img{aspect-ratio:16/10.2}
.env__side{display:grid;gap:clamp(14px,2vw,24px)}
.env figcaption{font-size:12.5px;color:var(--ink2);margin-top:10px;font-weight:700}
.env figcaption::before{content:"— ";color:var(--red)}

/* ---------- もっと知る（＋丸ボタンリンク） ---------- */
.lk{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
@media(max-width:880px){.lk{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.lk{grid-template-columns:1fr}}
.lk a{display:block;background:#fff;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 26px 32px;transition:background .15s}
.lk a:hover{background:var(--bg2)}
.lk__btn{display:block;width:32px;height:32px;border:1px solid var(--red);border-radius:50%;position:relative;margin-bottom:16px;transition:background .15s}
.lk__btn::before,.lk__btn::after{content:"";position:absolute;left:50%;top:50%;background:var(--red);transform:translate(-50%,-50%);transition:background .15s}
.lk__btn::before{width:12px;height:1.5px}
.lk__btn::after{width:1.5px;height:12px}
.lk a:hover .lk__btn{background:var(--red)}
.lk a:hover .lk__btn::before,.lk a:hover .lk__btn::after{background:#fff}
.lk__t{font-weight:900;font-size:16.5px;margin-bottom:8px}
.lk__x{font-size:13px;color:var(--ink2);line-height:1.9}

/* ---------- CTA帯 ---------- */
.cta{position:relative;background-color:#E8F3F8;background-image:var(--tex);background-repeat:repeat;text-align:center;padding:clamp(56px,8vw,96px) 0;border-top:1px solid var(--tint-line)}
.cta .w{position:relative}
.cta__t{font-weight:900;font-size:clamp(23px,3.2vw,32px);line-height:1.55}
.cta__x{font-size:14px;margin-top:12px;color:var(--ink2)}
.cta__b{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:30px}
.cta .btn--w{background:var(--red);color:#fff}
.cta .btn--k{background:#fff;color:var(--ink);border-color:var(--ink)}

/* ---------- フッター（淡色＋微テクスチャ） ---------- */
.ft{position:relative;background:#116EEC;border-top:1px solid #0E5FCC;font-size:13.5px;color:#EAF2FE}
.ft::before{content:"";position:absolute;inset:0;background-image:var(--grid-ft);pointer-events:none}
.ft .w{position:relative}
.ft__g{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding:clamp(48px,6vw,72px) 0 40px}
@media(max-width:880px){.ft__g{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.ft__g{grid-template-columns:1fr}}
.ft h3{font-family:var(--en);font-weight:700;font-size:11.5px;letter-spacing:.22em;color:#BBD4FA;text-transform:uppercase;margin-bottom:16px}
.ft ul{display:grid;gap:10px}
.ft a{color:#FFFFFF}
.ft a:hover{text-decoration:underline}
.ft__bt{border-top:1px solid rgba(255,255,255,.28);padding:18px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12px;color:#CFE0FB}

/* reveal */
.rv{opacity:0;transform:translateY(12px);transition:opacity .5s,transform .5s}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}}
:focus-visible{outline:2px solid var(--red);outline-offset:2px}

/* =====================================================================
   下層ページ用コンポーネント
   ===================================================================== */
/* ページヒーロー（写真＋白パネル見出し：MVの縮小版言語） */
.phero{position:relative;background:#1A1A1A}
.phero__img{width:100%;height:clamp(220px,30vh,340px);object-fit:cover;opacity:.92}
.phero__in{position:absolute;inset:0;display:flex;align-items:flex-end}
.phero__panel{background:rgba(255,255,255,.97);border-top:4px solid var(--red);padding:20px 28px 18px;max-width:560px;margin:0 0 -1px;display:flex;flex-direction:column-reverse}
.phero__en{font-family:var(--en);font-weight:700;font-size:10px;letter-spacing:.3em;color:#8DA2C4;text-transform:uppercase;margin-top:6px}
.phero__t{font-weight:900;font-size:clamp(22px,3vw,30px);line-height:1.4;margin-top:0}
@media(max-width:640px){.phero__img{height:160px}.phero__panel{max-width:none;width:100%;padding:16px var(--px) 14px}}

/* パンくず */
.crumb{border-bottom:1px solid var(--line);font-size:12px;color:var(--ink3)}
.crumb .w{display:flex;gap:8px;flex-wrap:wrap;padding-top:10px;padding-bottom:10px}
.crumb a:hover{color:var(--red)}

/* リード文 */
.lede{font-size:15px;color:var(--ink2);max-width:46em;line-height:2}

/* アンカーナビ */
.anav{display:flex;gap:10px;flex-wrap:wrap}
.anav a{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;padding:10px 20px;font-size:13px;font-weight:700}
.anav a::after{content:"↓";font-family:var(--en);color:var(--red);font-size:12px}
.anav a:hover{border-color:var(--red);color:var(--red)}

/* 写真×テキストの2分割 */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
@media(max-width:840px){.duo{grid-template-columns:1fr}}
.duo img{width:100%;aspect-ratio:3/2;object-fit:cover}

/* 写真カード3列 */
.pcards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.2vw,26px)}
@media(max-width:880px){.pcards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pcards{grid-template-columns:1fr}}
.pcard{background:#fff;border:1px solid var(--line)}
.pcard img{width:100%;aspect-ratio:3/2;object-fit:cover;display:block}
.pcard__b{padding:20px 22px 22px}
.pcard__t{font-weight:900;font-size:16.5px;margin-bottom:8px}
.pcard__t::before{content:"— ";color:var(--red)}
.pcard__x{font-size:13.5px;color:var(--ink2);line-height:1.9}

/* テーブル（spec拡張） */
.spec--c th,.spec--c td{text-align:center}
.spec--c th:first-child,.spec--c td:first-child{text-align:left}
.spec thead th{background:var(--red);color:#fff;border-color:#3E6FC4;text-align:center}
.spec td .em{font-weight:700;color:var(--red);font-family:var(--en)}
.tblwrap{overflow-x:auto}
.tblwrap .spec{min-width:560px}

/* FAQ */
.faqd{background:#fff;border:1px solid var(--line);margin-bottom:10px}
.faqd summary{list-style:none;cursor:pointer;display:flex;gap:14px;align-items:flex-start;padding:18px 20px;font-weight:700;font-size:15px}
.faqd summary::-webkit-details-marker{display:none}
.faqd summary::before{content:"Q";font-family:var(--en);font-weight:700;color:#fff;background:var(--red);width:26px;height:26px;display:grid;place-items:center;flex-shrink:0;font-size:13px}
.faqd summary::after{content:"+";margin-left:auto;font-family:var(--en);color:var(--ink3);font-size:20px;line-height:1}
.faqd[open] summary::after{content:"−"}
.faqd__a{display:flex;gap:14px;padding:0 20px 20px;font-size:14px;color:var(--ink2);line-height:1.95}
.faqd__a::before{content:"A";font-family:var(--en);font-weight:700;color:#fff;background:var(--amber);width:26px;height:26px;display:grid;place-items:center;flex-shrink:0;font-size:13px}
.faqd__a p{margin:1px 0 0}

/* ステップ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:760px){.steps{grid-template-columns:1fr}}
.step{background:#fff;padding:22px 20px}
.step__no{font-family:var(--en);font-weight:700;color:var(--red);font-size:13px;letter-spacing:.12em}
.step__t{font-weight:900;font-size:15.5px;margin:6px 0 6px}
.step__x{font-size:12.5px;color:var(--ink2);line-height:1.85}

/* 日程リスト */
.dates{border-top:1px solid var(--line)}
.dates li{display:grid;grid-template-columns:150px 1fr auto;gap:18px;align-items:center;padding:16px 4px;border-bottom:1px solid var(--line);font-size:14px}
@media(max-width:640px){.dates li{grid-template-columns:1fr;gap:6px}}
.dates .d{font-family:var(--en);font-weight:700;color:var(--red)}
.dates .tag{display:inline-block;font-size:11px;font-weight:700;border:1px solid var(--line);padding:2px 10px;color:var(--ink2);margin-left:8px}

/* NEWS一覧 */
.newsl{border-top:1px solid var(--line)}
.newsl li{display:grid;grid-template-columns:110px 90px 1fr;gap:16px;align-items:center;padding:16px 4px;border-bottom:1px solid var(--line);font-size:14px}
@media(max-width:640px){.newsl li{grid-template-columns:110px 1fr}.newsl .c{grid-column:2}.newsl .t{grid-column:1/-1}}
.newsl time{font-family:var(--en);color:var(--ink3);font-size:13px}
.newsl .c{justify-self:start;font-size:11px;font-weight:700;border:1px solid var(--red);color:var(--red);padding:2px 10px}

/* フォーム */
.form{display:grid;gap:18px;max-width:640px}
.form label{font-weight:700;font-size:13.5px;display:grid;gap:7px}
.form .req{color:var(--red);font-size:11px;margin-left:6px}
.form input,.form select,.form textarea{font-family:inherit;font-size:14px;padding:12px 14px;border:1px solid #C9CFDA;background:#fff;width:100%}
.form input:focus,.form select:focus,.form textarea:focus{outline:2px solid var(--red);outline-offset:1px}
.form textarea{min-height:120px;resize:vertical}
.form-done{background:#E9F4F0;border:1px solid #BFE0D5;padding:16px 20px;font-weight:700;color:#1E6E5C}

/* 法務系プローズ */
.prose h2{font-size:18px;font-weight:900;margin:34px 0 10px;padding-left:12px;border-left:3px solid var(--red)}
.prose p,.prose li{font-size:14px;color:var(--ink2);line-height:2}
.prose ul{padding-left:1.4em;list-style:disc}
.prose ol{padding-left:1.4em}

/* フッター（濃色ベース）内の調整 */
.ft .logo__mk{background:#fff;color:#116EEC}
.ft .logo__nm{color:#fff}
.ft .logo__sb{color:#BBD4FA}

/* 納入金ボックス（JEC風の表組み的表示） */
.pbox{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);max-width:680px}
@media(max-width:560px){.pbox{grid-template-columns:1fr}}
.pbox>div{background:#fff;padding:16px 22px 18px}
.pbox__l{display:block;font-size:12px;font-weight:700;color:var(--ink2);padding-bottom:9px;border-bottom:1px solid var(--line);margin-bottom:10px}
.pbox__v{font-weight:900;font-size:24px;letter-spacing:.02em}
.pbox__v small{font-size:14px;font-weight:700;margin-left:2px}
