/* ============================================================
   site.css — 企画ポータル共通（app.css の変数を利用）
   ============================================================ */
.pagewrap{max-width:1160px;margin:0 auto;padding:0 clamp(16px,4vw,48px)}
section.blk{padding:clamp(46px,7vw,88px) 0;border-bottom:1px solid var(--paper-line)}
section.blk:last-of-type{border-bottom:none}
.tag{font-family:var(--serif-en);font-style:italic;color:var(--gold-deep);font-size:.95rem;letter-spacing:.03em;margin-bottom:14px}
.blk h2{font-family:var(--brush);font-weight:400 !important;font-size:clamp(1.5rem,3.4vw,2.3rem);line-height:1.45;margin-bottom:18px;font-weight:600}
.blk h3{font-family:var(--brush);font-size:1.2rem;margin:26px 0 10px}
.blk p{color:var(--ink-soft);font-size:1rem;line-height:1.95;max-width:66ch}
.blk p.lead{font-family:var(--serif-jp);color:var(--ink);font-size:clamp(1.05rem,2vw,1.2rem);line-height:1.9;max-width:60ch}
.blk p+p{margin-top:14px}
.blk strong{color:var(--ink);font-weight:700}

/* hero */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--paper) 0%,var(--gold-wash) 100%)}
.hero .inner{max-width:1160px;margin:0 auto;padding:clamp(48px,8vw,96px) clamp(16px,4vw,48px);display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero .eyebrow{font-family:var(--serif-en);font-style:italic;color:var(--gold-deep);font-size:1.05rem;margin-bottom:16px}
.hero h1{font-family:var(--brush);font-size:clamp(2.1rem,5.4vw,3.6rem);line-height:1.4;font-weight:400;margin-bottom:20px}
.hero h1 .accent{color:var(--gold-deep)}
.hero p{font-family:var(--serif-jp);color:var(--ink-soft);font-size:clamp(1rem,2vw,1.15rem);line-height:1.95;max-width:46ch}
.hero .cta{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}
.hero .cta a{font-family:var(--sans-jp);font-size:.95rem;padding:13px 26px;border-radius:30px;text-decoration:none;transition:.2s}
.hero .cta a.primary{background:var(--gold);color:#fff}
.hero .cta a.primary:hover{background:var(--gold-deep)}
.hero .cta a.ghost{border:1px solid var(--gold);color:var(--gold-deep)}
.hero .cta a.ghost:hover{background:#fff}
.hero .art{border-radius:16px;overflow:hidden}
.hero .art img{width:100%;height:auto;object-fit:contain;display:block}
@media(max-width:820px){.hero .inner{grid-template-columns:1fr}.hero .art{order:-1;max-height:280px}}

/* figure / image band */
figure.fig{margin:26px 0;border-radius:14px;overflow:hidden;border:1px solid var(--rule);background:var(--paper-warm)}
figure.fig img{width:100%;display:block}
figure.fig figcaption{padding:12px 18px;font-size:.82rem;color:var(--ink-faint);background:var(--paper)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,44px);align-items:center}
.split.rev .txt{order:2}
@media(max-width:760px){.split{grid-template-columns:1fr}.split.rev .txt{order:0}}

/* section cards */
.cardgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:26px}
.scard{display:block;text-decoration:none;color:inherit;border:1px solid var(--rule);border-radius:14px;overflow:hidden;background:var(--paper);transition:.2s}
.scard:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(58,53,45,.10);border-color:var(--gold)}
.scard .ph{aspect-ratio:16/10;overflow:hidden;background:var(--gold-wash)}
.scard .ph img{width:100%;height:100%;object-fit:cover;display:block}
.scard .bd{padding:18px 20px}
.scard .bd h4{font-family:var(--brush);font-size:1.1rem;margin-bottom:6px}
.scard .bd p{font-size:.86rem;color:var(--ink-soft);line-height:1.7;max-width:none}
.scard .bd .go{margin-top:10px;font-family:var(--serif-en);font-style:italic;color:var(--gold-deep);font-size:.85rem}

/* roles (連携の4層) */
.roles{display:grid;gap:12px;margin-top:22px}
.role{display:grid;grid-template-columns:56px 1fr;gap:16px;align-items:start;padding:18px 20px;border:1px solid var(--rule);border-radius:12px;background:var(--paper)}
.role .n{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--gold-wash);color:var(--gold-deep);font-family:var(--serif-en);font-size:1.1rem}
.role .h{font-family:var(--brush);font-weight:600;font-size:1.05rem;margin-bottom:3px}
.role .d{font-size:.9rem;color:var(--ink-soft);line-height:1.75}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:12px;overflow:hidden;margin:24px 0}
.stats .s{background:var(--paper);padding:22px 18px;text-align:center}
.stats .s .v{font-family:var(--serif-en);font-size:clamp(1.6rem,4vw,2.2rem);color:var(--gold-deep);line-height:1}
.stats .s .l{font-size:.8rem;color:var(--ink-soft);margin-top:8px;line-height:1.5}

/* calc / rows */
.calc{border:1px solid var(--rule);border-radius:12px;padding:22px 24px;margin:20px 0;background:var(--paper-warm)}
.calc .h{font-family:var(--serif-jp);font-weight:600;margin-bottom:14px;color:var(--gold-deep)}
.calc .r{display:flex;justify-content:space-between;gap:16px;padding:8px 0;border-bottom:1px dashed var(--rule);font-size:.92rem}
.calc .r:last-child{border-bottom:none}
.calc .r .lab{color:var(--ink-soft)}
.calc .r .val{font-family:var(--serif-en);color:var(--ink);white-space:nowrap}
.calc .foot{font-size:.8rem;color:var(--ink-faint);margin-top:12px;line-height:1.7}

/* note */
.note2{border-left:3px solid var(--coral);background:var(--coral-wash);padding:16px 20px;margin:18px 0;border-radius:0 8px 8px 0;font-size:.92rem;color:var(--ink-soft);line-height:1.85}
.note2.calm{border-left-color:var(--gold);background:var(--gold-wash)}
.note2 b{color:var(--ink)}
.note2 .k{display:block;font-family:var(--serif-en);font-style:italic;color:var(--coral-deep);font-size:.82rem;margin-bottom:6px}
.note2.calm .k{color:var(--gold-deep)}

/* table */
table.t{width:100%;border-collapse:collapse;margin:20px 0;font-size:.9rem}
table.t th,table.t td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--rule);vertical-align:top}
table.t th{font-family:var(--serif-jp);font-weight:600;color:var(--gold-deep);background:var(--gold-wash)}
table.t td.pos{color:var(--pos);font-weight:600}

/* quote/closing */
.closing{background:var(--gold-wash);text-align:center}
.closing .q{font-family:var(--brush);font-size:clamp(1.4rem,3.6vw,2.2rem);line-height:1.6;color:var(--ink);margin:0 auto;max-width:22ch}
.closing .q .em{color:var(--gold-deep)}

footer.site2{background:var(--ink);color:rgba(253,251,247,.62);padding:44px clamp(16px,4vw,48px);font-size:.8rem;line-height:1.85}
footer.site2 .brand{font-family:var(--serif-jp);color:#fff;font-size:1.1rem;margin-bottom:10px}
footer.site2 a{color:var(--gold-wash)}
footer.site2 .src{font-size:.72rem;color:rgba(253,251,247,.4);margin-top:12px}

/* 和 hero: centered text + full-width band */
.hero .inner.wa{display:block;max-width:860px;margin:0 auto;text-align:center;padding-bottom:34px}
.hero .inner.wa .cta{justify-content:center}
.hero .inner.wa p{margin-left:auto;margin-right:auto}
.waband{width:100%;line-height:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.waband img{width:100%;height:auto;display:block;max-height:56vh;object-fit:cover;object-position:center 60%}

/* plain figure (no frame) for illustrations/photos */
figure.fig.plain{border:none;background:transparent;margin:22px 0}
figure.fig.plain img{width:100%;display:block;border-radius:12px}

/* investment quick cards */
.scard.flat{cursor:default}
.scard.flat:hover{transform:none;box-shadow:none;border-color:var(--rule)}
.scard.flat .bd{padding:20px 22px}
.scard.flat .idx{font-family:var(--brush);color:var(--gold-deep);font-size:1.3rem;margin-bottom:4px}
.scard.flat .ret{margin-top:10px;font-family:var(--serif-en);color:var(--gold-deep);font-weight:600;font-size:1.05rem;border-top:1px solid var(--rule);padding-top:8px}

/* brush title tuning */
.brand .en,.tag,.eyebrow{font-family:var(--serif-en)}

/* ===== 開幕 entrance ===== */
body.locked{overflow:hidden}
.maku{position:fixed;inset:0;z-index:9999;background:#faf6ec;overflow:hidden}
.maku.gone{opacity:0;pointer-events:none;transition:opacity 1.1s ease}
.maku .kaimaku{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1;display:flex;align-items:center;gap:1vw}
.maku .kchar{height:66vh;width:auto;opacity:0}
.maku .kchar.writing{opacity:1;animation:brushReveal 2.1s cubic-bezier(.4,0,.2,1) forwards}
@keyframes brushReveal{
 0%{-webkit-mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,0) 5%,rgba(0,0,0,0) 100%);mask-image:linear-gradient(to bottom,#000 0%,rgba(0,0,0,0) 5%,rgba(0,0,0,0) 100%)}
 100%{-webkit-mask-image:linear-gradient(to bottom,#000 0%,#000 100%,rgba(0,0,0,0) 100%);mask-image:linear-gradient(to bottom,#000 0%,#000 100%,rgba(0,0,0,0) 100%)}
}
.byobu{position:absolute;inset:0;z-index:10;display:flex}
.byobu .pl,.byobu .pr{width:50vw;height:100vh;overflow:hidden;transition:transform 1.3s cubic-bezier(.25,.46,.45,.94);will-change:transform}
.byobu .pl img{width:200%;height:100%;object-fit:cover;object-position:left;display:block}
.byobu .pr img{width:200%;height:100%;object-fit:cover;object-position:right;margin-left:-100%;display:block}
.maku.open .byobu .pl{transform:translateX(-100%)}
.maku.open .byobu .pr{transform:translateX(100%)}
.maku .hint{position:absolute;bottom:8%;left:50%;transform:translateX(-50%);z-index:20;cursor:pointer;text-align:center;transition:opacity .4s}
.maku .hint img{width:104px;height:auto;animation:floatSensu 2.2s ease-in-out infinite}
.maku .hint span{display:block;margin-top:6px;font-family:var(--brush);color:var(--gold-deep);font-size:1rem;letter-spacing:.3em}
.maku.open .hint{opacity:0;pointer-events:none}
@keyframes floatSensu{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-10px) rotate(4deg)}}

/* ===== full-bleed hero ===== */
.wahero{position:relative;min-height:74vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;border-bottom:1px solid var(--rule)}
.wahero .bg{position:absolute;inset:0;background-size:cover;background-position:center 62%}
.wahero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(250,246,236,.55) 0%,rgba(250,246,236,.15) 40%,rgba(250,246,236,.75) 100%)}
.wahero .inner{position:relative;z-index:2;padding:60px 24px;max-width:900px}
.wahero .brandmark{height:96px;width:auto;margin:0 auto 22px;display:block}
.wahero .eyebrow{font-family:var(--serif-en);font-style:italic;color:var(--gold-deep);font-size:1.05rem;margin-bottom:14px}
.wahero h1{font-family:var(--brush);font-weight:400;font-size:clamp(2.4rem,7vw,4.6rem);line-height:1.32;color:var(--ink);margin-bottom:20px;text-shadow:0 1px 0 rgba(250,246,236,.6)}
.wahero h1 .accent{color:var(--gold-deep)}
.wahero p{font-family:var(--serif-jp);color:var(--ink-soft);font-size:clamp(1rem,2vw,1.18rem);line-height:1.95;max-width:44ch;margin:0 auto 26px}
.wahero .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.wahero .cta a{font-family:var(--sans-jp);font-size:.98rem;padding:13px 28px;border-radius:30px;text-decoration:none;transition:.2s}
.wahero .cta a.primary{background:var(--gold);color:#fff}
.wahero .cta a.primary:hover{background:var(--gold-deep)}
.wahero .cta a.ghost{border:1px solid var(--gold);color:var(--gold-deep);background:rgba(250,246,236,.6)}
.wahero .cta a.ghost:hover{background:#fff}

/* ===== image-background sections ===== */
.imgblk{position:relative;overflow:hidden;border-bottom:1px solid var(--rule)}
.imgblk .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.imgblk .scrim{position:absolute;inset:0}
.imgblk.light .scrim{background:rgba(250,246,236,.82)}
.imgblk.side .scrim{background:linear-gradient(90deg,rgba(250,246,236,.95) 0%,rgba(250,246,236,.86) 46%,rgba(250,246,236,.35) 100%)}
.imgblk .inner{position:relative;z-index:2;max-width:1160px;margin:0 auto;padding:clamp(52px,8vw,96px) clamp(16px,4vw,48px)}
.imgblk .inner.narrow{max-width:720px}
.imgblk h2{font-family:var(--brush);font-weight:400;font-size:clamp(1.7rem,3.8vw,2.6rem);line-height:1.45;margin-bottom:16px;color:var(--ink)}
.imgblk p{font-family:var(--serif-jp);color:var(--ink-soft);font-size:1.02rem;line-height:1.95;max-width:60ch}
.imgblk .tag{font-family:var(--serif-en);font-style:italic;color:var(--gold-deep);font-size:.95rem;margin-bottom:12px}
.imgblk .cta2{margin-top:24px}
.imgblk .cta2 a{font-family:var(--sans-jp);font-size:.95rem;padding:12px 26px;border-radius:30px;text-decoration:none;background:var(--gold);color:#fff}
.imgblk .cta2 a:hover{background:var(--gold-deep)}
/* dark scrim variant for photos, white text */
.imgblk.dark .scrim{background:linear-gradient(180deg,rgba(43,38,33,.35),rgba(43,38,33,.66))}
.imgblk.dark h2,.imgblk.dark p{color:#faf6ec}
.imgblk.dark .tag{color:#e3c98c}

/* header logo */
.site .brand .lg{height:30px;width:auto;vertical-align:middle;margin-right:10px}
