/* =========================================================
   site.css — J's × Dityca 統合採用LP 共有デザインシステム v12
   「品ある華やかさ」Direction B（生成り×臙脂×くすみローズ／見出し明朝×本文ゴシック）
   top.html / js.html / dityca.html で共有。recruit-diagnose.html は自己完結（同トークン）。
   写真は仮（本番は LIM 撮影内製に差し替え）。
   ========================================================= */

:root{
  --bg:#FAF6F3; --bg-2:#F3ECE6; --bg-3:#EBE0D9; --ink-bg:#2A211F;
  --ink:#241C1A; --ink-2:#48403B; --ink-3:#7A6E66; --ink-4:#C9BEB6; --paper:#FBF6F4; --paper-2:#E0D4CF;
  --accent:#B23A48; --accent-deep:#8E2C38;
  --rose:#C98B86; --rose-deep:#B26F6A; --rose-soft:rgba(201,139,134,0.14);
  --line:rgba(42,33,31,0.14); --line-soft:rgba(42,33,31,0.07);
  --ja:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --mincho:"Noto Serif JP",serif;
  --en:"Instrument Serif","Times New Roman",serif;
  --ease:cubic-bezier(0.16,1,0.3,1);
  --pad:clamp(20px,5vw,80px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
img{max-width:100%;display:block}
body{font-family:var(--ja);font-weight:400;background:var(--bg);color:var(--ink);line-height:1.9;
  -webkit-font-smoothing:antialiased;font-feature-settings:"palt";word-break:auto-phrase;line-break:strict;overflow-x:hidden}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
em{font-style:normal}
.mincho{font-family:var(--mincho)}
.en{font-family:var(--en);font-style:italic}
.eyebrow{font-family:var(--en);font-style:italic;font-size:15px;color:var(--rose-deep);letter-spacing:.02em}
.label{font-family:var(--ja);font-size:10.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.bg-2{background:var(--bg-2)}
.bg-ink{background:var(--ink-bg);color:var(--paper)}

/* ---------- brand logos (PSD: logo_2026 → 透過PNG) ---------- */
.l-js,.l-dty{display:block;width:auto}
.lockup{display:inline-flex;align-items:center;gap:11px}
.lockup .x{font-family:var(--en);font-style:italic;color:var(--rose-deep);font-size:18px;line-height:1}
/* 字高(cap-height)比が両者ほぼ同じ(0.72/0.73)→「Dityca高さ ≒ J's高さ」で揃う（measure_logos.py） */
.hdr__brand.lockup .l-js{height:30px}
.hdr__brand.lockup .l-dty{height:29px}
.hero__brands .l-js{height:46px}
.hero__brands .l-dty{height:45px}
/* 分岐リンク：J's エンブレムと Dityca 正方形ロゴ(logo_wh)を大きく・サイズ統一 */
.brandlink__mark{flex:0 0 92px;display:flex;align-items:center;justify-content:flex-start}
.brandlink--js .l-js{height:68px}
.brandlink--dityca .l-dty{height:68px}
.brandcard__name .l-js{height:54px}
.brandcard__name .l-dty{height:52px}
.bhero__logo .l-js{height:56px}
.bhero__logo .l-dty{height:54px}
.foot h5.lockup .l-js{height:34px}
.foot h5.lockup .l-dty{height:33px}

/* ---------- header ---------- */
.hdr{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s var(--ease)}
.hdr.scrolled{background:rgba(250,246,243,.92);backdrop-filter:blur(12px);padding:12px var(--pad);box-shadow:0 1px 0 var(--line)}
.hdr--solid{background:rgba(250,246,243,.96);box-shadow:0 1px 0 var(--line)}
.hdr__brand{font-family:var(--mincho);font-weight:500;font-size:20px;letter-spacing:.04em}
.hdr__brand .x{color:var(--rose-deep);font-family:var(--en);font-style:italic;margin:0 .15em}
.hdr__nav{display:none;gap:30px}
@media(min-width:960px){.hdr__nav{display:flex}}
.hdr__nav a{font-size:12px;letter-spacing:.1em;color:var(--ink-2);transition:color .3s}
.hdr__nav a:hover{color:var(--accent)}
.hdr__nav a.is-current{color:var(--accent);border-bottom:1px solid var(--accent);padding-bottom:2px}
.hdr__cta{font-size:12px;font-weight:500;letter-spacing:.06em;padding:11px 22px;background:var(--accent);color:#fff;transition:background .3s}
.hdr__cta:hover{background:var(--accent-deep)}

/* ---------- breadcrumb (sub pages) ---------- */
.crumb{max-width:1340px;margin:0 auto;padding:96px var(--pad) 0}
.crumb a,.crumb span{font-size:11.5px;letter-spacing:.08em;color:var(--ink-3)}
.crumb a:hover{color:var(--accent)}
.crumb .sep{margin:0 9px;color:var(--ink-4)}
.crumb .cur{color:var(--ink);font-weight:500}

/* ---------- hero (top: asymmetric split) ---------- */
.hero{display:grid;grid-template-columns:1fr;min-height:100svh;position:relative}
@media(min-width:980px){.hero{grid-template-columns:1.05fr .95fr}}
.hero__left{display:flex;flex-direction:column;justify-content:center;padding:130px var(--pad) 64px;position:relative;z-index:2;background:var(--bg)}
.hero__eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.hero__eyebrow::before{content:"";width:46px;height:1px;background:var(--rose-deep)}
.hero__title{font-family:var(--mincho);font-weight:500;font-size:clamp(26px,7vw,88px);line-height:1.28;letter-spacing:.01em}
.hero__title em{color:var(--accent)}
.hero__title .en{display:block;font-size:clamp(18px,2.2vw,30px);color:var(--rose-deep);margin-top:18px;font-weight:400}
.hero__sub{font-size:clamp(14px,1.1vw,15.5px);color:var(--ink-2);line-height:2.15;margin:34px 0 12px;max-width:30em}
.hero__brands{display:flex;align-items:center;flex-wrap:wrap;gap:12px 14px;font-family:var(--mincho);font-weight:500;font-size:18px;color:var(--ink);margin-top:30px;padding-top:24px;border-top:1px solid var(--line)}
.hero__brands .x{color:var(--rose-deep);font-family:var(--en);font-style:italic}
.hero__brands small{font-family:var(--ja);font-weight:400;font-size:11.5px;color:var(--ink-3);letter-spacing:.04em;width:100%;margin-top:2px}
.hero__right{position:relative;min-height:46vh;overflow:hidden}
.hero__right img{width:100%;height:100%;object-fit:cover;object-position:center;animation:kb 26s ease-in-out infinite alternate}
@keyframes kb{from{transform:scale(1)}to{transform:scale(1.07)}}
.hero__right::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(250,246,243,.55) 0%,transparent 26%)}
.hero__tagvert{position:absolute;right:18px;bottom:24px;z-index:3;font-family:var(--en);font-style:italic;font-size:13px;color:var(--paper);writing-mode:vertical-rl;letter-spacing:.1em;text-shadow:0 1px 6px rgba(0,0,0,.4)}

/* ---------- brand hero (sub pages) ---------- */
.bhero{display:grid;grid-template-columns:1fr;align-items:stretch;border-bottom:1px solid var(--line)}
@media(min-width:980px){.bhero{grid-template-columns:1fr 1fr}}
.bhero__body{padding:clamp(36px,5vw,80px) var(--pad) clamp(48px,6vw,90px);display:flex;flex-direction:column;justify-content:center;min-width:0}
.bhero__logo{margin-bottom:26px}
.bhero__title{font-family:var(--mincho);font-weight:500;font-size:clamp(28px,4vw,52px);line-height:1.4;letter-spacing:.02em;margin-bottom:18px}
@media(max-width:380px){.bhero__title{font-size:23px}}
.bhero__title em{color:var(--accent)}
.bhero__lead{font-size:14.5px;color:var(--ink-2);line-height:2.15;max-width:34em}
.bhero__roles{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}
.bhero__roles span{font-size:11.5px;font-weight:500;letter-spacing:.05em;padding:8px 15px;border:1px solid var(--line);color:var(--ink-2)}
.bhero__photo{min-height:48vh;position:relative;overflow:hidden}
.bhero__photo img{width:100%;height:100%;object-fit:cover}

/* ---------- section frame ---------- */
section{padding:clamp(72px,11vw,150px) var(--pad)}
.wrap{max-width:1340px;margin:0 auto}
.shead{display:flex;flex-direction:column;gap:14px;margin-bottom:clamp(40px,6vw,72px)}
.shead h2{font-family:var(--mincho);font-weight:500;font-size:clamp(26px,4vw,50px);line-height:1.4;letter-spacing:.02em;word-break:keep-all}
@media(max-width:360px){.shead h2{font-size:23px}}
/* 見出し・カードタイトルは語中で折らない（iOS対策・line-break-check 由来） */
.hero__title,.bhero__title,.story__q,.diag-card h3,.pres__title,.crew__head h3,.inc__title,.feat__t,.final h2,.role__name{word-break:keep-all}
/* グリッド/フレックス子の min-content 膨張を防ぐ（横はみ出し対策・line-break-check 由来） */
.hero>*,.bhero>*,.spine__grid>*,.brands__list>*,.nums__grid>*,.roles__grid>*,.income__grid>*,.crew>*,.decided>*{min-width:0}
@media(max-width:400px){.diag-card{padding:30px 22px}.diag-card h3{font-size:20px}}
@media(max-width:360px){.role__name{font-size:18px}}
.shead h2 em{color:var(--accent)}
.shead .en{font-size:clamp(15px,1.6vw,20px);color:var(--rose-deep)}
.shead p{font-size:14.5px;color:var(--ink-2);line-height:2.1;max-width:40em}

/* ---------- DIAGNOSIS BACKBONE (top) ---------- */
.spine{background:var(--bg-2)}
.spine__grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:900px){.spine__grid{grid-template-columns:1.4fr 1fr;gap:clamp(28px,4vw,56px);align-items:stretch}}
.diag-card{position:relative;background:var(--ink-bg);color:var(--paper);padding:clamp(36px,5vw,64px);overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.diag-card::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 85% 15%,rgba(201,139,134,.22),transparent 60%),radial-gradient(ellipse at 10% 90%,rgba(178,58,72,.18),transparent 55%)}
.diag-card>*{position:relative;z-index:1}
.diag-card .eyebrow{color:var(--rose)}
.diag-card h3{font-family:var(--mincho);font-weight:500;font-size:clamp(24px,3.2vw,40px);line-height:1.45;margin:16px 0 16px}
.diag-card h3 em{color:var(--rose)}
.diag-card p{font-size:14px;color:var(--paper-2);line-height:2.05;max-width:32em;margin-bottom:30px}
.diag-card__stats{display:flex;gap:28px;margin-bottom:32px;flex-wrap:wrap}
.diag-card__stats div{font-size:11.5px;color:var(--paper-2)}
.diag-card__stats b{display:block;font-family:var(--en);font-style:normal;font-size:28px;color:var(--rose);line-height:1}
.diag-card__btn{align-self:flex-start;display:inline-flex;align-items:center;gap:12px;background:var(--accent);color:#fff;
  font-size:14px;font-weight:500;letter-spacing:.04em;padding:17px 34px;transition:background .3s,gap .3s}
.diag-card__btn:hover{background:var(--accent-deep);gap:18px}
.decided{display:flex;flex-direction:column;gap:18px}
.decided__lead{font-size:13.5px;color:var(--ink-2);line-height:1.9}
.decided__lead b{font-family:var(--mincho);font-weight:500;color:var(--ink)}
.brandlink{position:relative;display:flex;align-items:center;gap:20px;background:var(--bg);border:1px solid var(--line);padding:22px 26px;
  transition:border-color .3s,transform .3s,box-shadow .3s;flex:1}
.brandlink:hover{border-color:var(--rose-deep);transform:translateX(4px);box-shadow:-4px 0 0 var(--rose)}
.brandlink__mark{font-family:var(--mincho);font-weight:700;font-size:26px;line-height:1;color:var(--ink)}
.brandlink--dityca .brandlink__mark{color:var(--accent)}
.brandlink__body{flex:1;min-width:0}
.brandlink__body .t{display:block;font-size:14px;font-weight:500;color:var(--ink);white-space:nowrap}
.brandlink__body .d{display:block;font-size:11.5px;color:var(--ink-3);margin-top:4px}
/* モバイル：ロゴ枠と余白を圧縮し、所在地を1行に収める */
@media(max-width:560px){
  .brandlink{gap:14px;padding:18px 18px}
  .brandlink__mark{flex-basis:54px}
  .brandlink--js .l-js{height:46px}
  .brandlink--dityca .l-dty{height:46px}
  .brandlink__body .d{font-size:11px;letter-spacing:-.01em}
}
.brandlink__arr{font-family:var(--en);font-style:italic;color:var(--rose-deep);font-size:18px}

/* ---------- NUMBERS band ---------- */
.nums{background:var(--bg)}
.nums__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,5vw,64px) clamp(20px,4vw,48px)}
@media(min-width:860px){.nums__grid{grid-template-columns:repeat(4,1fr)}}
.num{position:relative}
.num__v{font-family:var(--en);font-style:normal;font-size:clamp(58px,8vw,108px);line-height:.9;color:var(--ink);letter-spacing:-.01em}
.num__v sup{font-size:.3em;color:var(--accent);vertical-align:super;margin-left:4px;font-style:italic}
.num__v::after{content:"";display:block;width:38px;height:2px;background:var(--rose);margin:18px 0 0}
/* 数字でなく漢字の値（例：育休）は、英数字フォントの大サイズだと大きく見えるため明朝で小さめに揃える */
.num__v--text{font-family:var(--mincho);font-size:clamp(38px,5vw,66px);font-weight:500;letter-spacing:.04em;line-height:1.05}
.num__v--text sup{font-size:.42em;vertical-align:super}
.num__l{font-family:var(--mincho);font-weight:500;font-size:15px;color:var(--ink);margin:16px 0 6px}
.num__d{font-size:12.5px;color:var(--ink-2);line-height:1.95}
.num__src{display:inline-block;font-size:10px;font-weight:500;letter-spacing:.12em;padding:4px 10px;border:0;color:#fff;margin-bottom:16px}
.num__src--js{background:var(--ink)}
.num__src--dty{background:var(--accent)}
.num__src--both{background:var(--rose-deep)}
.nums__note{margin-top:clamp(36px,5vw,56px);font-size:11.5px;color:var(--ink-3);line-height:1.95;border-top:1px solid var(--line-soft);padding-top:18px}

/* ---------- TWO BRANDS (top) ---------- */
.brands{background:var(--bg-2)}
.brands__list{display:grid;grid-template-columns:1fr;gap:clamp(28px,4vw,40px)}
@media(min-width:900px){.brands__list{grid-template-columns:1fr 1fr}}
.brandcard{position:relative;display:flex;flex-direction:column;background:var(--bg);overflow:hidden;border:1px solid var(--line);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.brandcard:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(42,33,31,.4)}
.brandcard__photo{aspect-ratio:16/11;overflow:hidden;position:relative}
.brandcard__photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.brandcard:hover .brandcard__photo img{transform:scale(1.05)}
.brandcard__tag{position:absolute;top:18px;left:18px;font-family:var(--en);font-style:italic;font-size:13px;color:var(--paper);background:rgba(42,33,31,.55);padding:5px 14px;backdrop-filter:blur(4px)}
.brandcard__body{padding:clamp(26px,3vw,40px)}
.brandcard__name{font-family:var(--mincho);font-weight:700;font-size:clamp(26px,3vw,38px);letter-spacing:.04em;line-height:1}
.brandcard__roles{font-size:12px;letter-spacing:.1em;color:var(--rose-deep);margin:14px 0 16px;text-transform:uppercase;font-family:var(--ja);font-weight:500}
.brandcard__desc{font-size:13.5px;color:var(--ink-2);line-height:2.05;margin-bottom:24px}
.brandcard__cta{display:inline-flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:5px;transition:gap .3s,color .3s,border-color .3s}
.brandcard__cta:hover{gap:16px;color:var(--accent);border-color:var(--accent)}

/* ---------- ROLES (brand pages) ---------- */
.roles__grid{display:grid;grid-template-columns:1fr;gap:clamp(22px,3vw,30px)}
@media(min-width:740px){.roles__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1080px){.roles--3 .roles__grid{grid-template-columns:repeat(3,1fr)}}
.role{border:1px solid var(--line);background:var(--bg);overflow:hidden;display:flex;flex-direction:column}
.role__photo{aspect-ratio:4/3;overflow:hidden}
.role__photo img{width:100%;height:100%;object-fit:cover}
.role__body{padding:28px 26px;flex:1;display:flex;flex-direction:column}
.role__no{font-family:var(--en);font-style:italic;color:var(--rose-deep);font-size:15px;margin-bottom:8px}
.role__name{font-family:var(--mincho);font-weight:500;font-size:21px;margin-bottom:4px}
.role__en{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px}
.role__desc{font-size:13px;color:var(--ink-2);line-height:2}
.role__chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.role__chips span{font-size:10.5px;letter-spacing:.04em;padding:5px 11px;background:var(--bg-2);color:var(--ink-2)}

/* ---------- INCOME (brand pages) ---------- */
.income__grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:860px){.income__grid{grid-template-columns:repeat(3,1fr)}}
.inc{background:var(--bg);padding:34px 28px}
.inc__role{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--rose-deep);font-weight:500;margin-bottom:14px}
.inc__title{font-family:var(--mincho);font-weight:500;font-size:18px;margin-bottom:18px;line-height:1.5}
.inc__num{font-family:var(--en);font-style:normal;font-size:clamp(34px,4vw,46px);color:var(--ink);line-height:1}
.inc__num small{font-size:.32em;color:var(--ink-3);margin-left:6px}
.inc__detail{font-size:12.5px;color:var(--ink-2);line-height:1.95;margin-top:16px}
.inc__note{font-family:var(--en);font-style:italic;font-size:11.5px;color:var(--accent);margin-top:14px}

/* ---------- STORIES (brand pages) ---------- */
.story{display:grid;grid-template-columns:1fr;gap:32px;align-items:center;padding:clamp(40px,5vw,64px) 0;border-top:1px solid var(--line)}
@media(min-width:900px){.story{grid-template-columns:5fr 7fr;gap:56px}.story:nth-child(even){direction:rtl}.story:nth-child(even)>*{direction:ltr}}
.story__photo{aspect-ratio:4/5;overflow:hidden}
.story__photo img{width:100%;height:100%;object-fit:cover}
.story__role{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--rose-deep);font-weight:500;margin-bottom:14px}
.story__q{font-family:var(--mincho);font-weight:500;font-size:clamp(20px,2.4vw,28px);line-height:1.6;margin-bottom:20px}
.story__p{font-size:13.5px;color:var(--ink-2);line-height:2.1;margin-bottom:14px}
.story__name{margin-top:20px;padding-top:16px;border-top:1px solid var(--line);font-family:var(--en);font-style:italic;font-size:14px;color:var(--ink)}
.story__name small{display:block;font-family:var(--ja);font-style:normal;font-size:11px;color:var(--ink-3);margin-top:4px}
.story__pending{border-top:1px solid var(--line);padding-top:clamp(40px,5vw,64px);margin-top:0}
.story__pending .box{background:var(--rose-soft);border-left:2px solid var(--rose);padding:26px 30px;font-size:13.5px;color:var(--ink-2);line-height:2.05}
.story__pending b{color:var(--accent);font-weight:500}

/* ---------- crew grid (若手スタッフ) ---------- */
.crew__head{margin:clamp(48px,6vw,72px) 0 28px;padding-top:clamp(40px,5vw,56px);border-top:1px solid var(--line)}
.crew__head .label{display:block;margin-bottom:12px}
.crew__head h3{font-family:var(--mincho);font-weight:500;font-size:clamp(20px,2.6vw,30px);line-height:1.5}
.crew__head h3 em{color:var(--accent)}
.crew__head p{font-size:13.5px;color:var(--ink-2);line-height:2;max-width:38em;margin-top:12px}
.crew{display:grid;grid-template-columns:1fr;gap:clamp(18px,3vw,24px)}
@media(min-width:760px){.crew{grid-template-columns:repeat(3,1fr)}}
.crewcard{background:var(--bg);border:1px solid var(--line);overflow:hidden}
.crewcard__photo{aspect-ratio:3/4;overflow:hidden}
.crewcard__photo img{width:100%;height:100%;object-fit:cover}
.crewcard__body{padding:16px 18px 20px}
.crewcard__role{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--rose-deep);font-weight:500}
.crewcard__name{font-family:var(--mincho);font-weight:500;font-size:16px;margin:7px 0}
.crewcard__name small{font-family:var(--ja);font-weight:400;font-size:11px;color:var(--ink-3);margin-left:7px}
.crewcard__c{font-size:12px;color:var(--ink-2);line-height:1.9}

/* ---------- ACCESS (brand pages) ---------- */
.salons{border-top:1px solid var(--line)}
.salon{padding:24px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:760px){.salon{grid-template-columns:1fr auto;align-items:center;gap:24px}}
.salon__name{font-family:var(--mincho);font-weight:500;font-size:18px}
.salon__name small{font-family:var(--en);font-style:italic;font-size:11px;color:var(--accent);margin-left:10px}
.salon__addr{font-size:12.5px;color:var(--ink-2);margin-top:5px;line-height:1.8}
.salon__tags{display:flex;gap:6px;flex-wrap:wrap}
.salon__tags span{font-size:10px;letter-spacing:.06em;padding:5px 11px;border:1px solid var(--line);color:var(--ink-3)}

/* ---------- FLOW (brand pages) ---------- */
.flow__steps{display:grid;grid-template-columns:1fr}
.fstep{display:grid;grid-template-columns:1fr;gap:12px;padding:30px 0;border-top:1px solid var(--line)}
@media(min-width:800px){.fstep{grid-template-columns:72px 1fr 150px;gap:36px;align-items:start}}
.fstep__no{font-family:var(--en);font-style:normal;font-size:42px;color:var(--rose-deep);line-height:1}
.fstep__t{font-family:var(--mincho);font-weight:500;font-size:19px;margin-bottom:8px}
.fstep__t small{display:block;font-family:var(--en);font-style:italic;font-size:11px;color:var(--rose-deep);margin-bottom:6px}
.fstep__d{font-size:13px;color:var(--ink-2);line-height:2}
.fstep__ok{font-family:var(--en);font-style:italic;font-size:12px;color:var(--accent);margin-top:10px}
.fstep__dur{font-size:11.5px;color:var(--ink-3);border:1px solid var(--line);padding:6px 12px;display:inline-block;align-self:start;justify-self:start}

/* ---------- FAQ (brand pages) ---------- */
.faq__list{max-width:880px}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{padding:24px 42px 24px 0;cursor:pointer;list-style:none;position:relative;font-family:var(--mincho);font-weight:500;font-size:15.5px;line-height:1.6}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:22px;font-family:var(--en);color:var(--accent);font-size:24px;font-style:normal}
.faq-item details[open] summary::after{content:"\2212"}
.faq-item .a{padding:0 0 26px;font-size:13.5px;color:var(--ink-2);line-height:2.15}

/* ---------- president / 代表メッセージ ---------- */
.pres{background:var(--ink-bg);color:var(--paper);position:relative;overflow:hidden}
.pres::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 85% 12%,rgba(201,139,134,.16),transparent 60%)}
.pres__in{position:relative;z-index:1;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:980px){.pres__in{grid-template-columns:5fr 7fr;gap:72px;align-items:center}}
.pres__photo{aspect-ratio:4/5;max-width:380px;overflow:hidden}
.pres__photo img{width:100%;height:100%;object-fit:cover}
.pres__label{font-family:var(--en);font-style:italic;font-size:14px;color:var(--rose);display:block;margin-bottom:18px}
.pres__title{font-family:var(--mincho);font-weight:500;font-size:clamp(22px,3vw,38px);line-height:1.55;margin-bottom:26px}
.pres__title em{color:var(--rose)}
.pres__q{font-family:var(--mincho);font-weight:500;font-size:clamp(15px,1.4vw,19px);line-height:2;border-left:1px solid var(--rose);padding-left:22px;margin-bottom:28px;color:var(--paper)}
.pres__p{font-size:13.5px;color:var(--paper-2);line-height:2.1;margin-bottom:16px;max-width:40em}
.pres__sign{margin-top:26px;font-family:var(--mincho);font-weight:500;font-size:16px}
.pres__sign small{display:block;font-family:var(--ja);font-weight:400;font-size:11px;color:var(--paper-2);margin-top:6px}
.pres__link{display:inline-flex;align-items:center;gap:8px;margin-top:20px;font-size:13px;font-weight:500;color:var(--rose);border-bottom:1px solid var(--rose);padding-bottom:4px;transition:color .25s,border-color .25s,gap .25s}
.pres__link:hover{color:var(--paper);border-color:var(--paper);gap:13px}

/* ---------- feature grid (education etc) ---------- */
.feat{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:680px){.feat{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.feat{grid-template-columns:repeat(3,1fr)}}
.feat__item{background:var(--bg);padding:32px 28px}
.feat__photo{aspect-ratio:4/3;background:#e7e2db;border:1px dashed #cbc3b8;border-radius:6px;margin-bottom:20px;display:flex;align-items:center;justify-content:center}
.feat__photo::after{content:"PHOTO";font-family:var(--en);letter-spacing:.22em;font-size:11px;color:#b0a89d}
.feat__photo img{width:100%;height:100%;object-fit:cover;border-radius:6px;display:block}
.feat__photo:has(img){border:none;background:transparent}
.feat__photo:has(img)::after{content:none}
.feat__n{font-family:var(--en);font-style:italic;color:var(--rose-deep);font-size:15px;margin-bottom:12px}
.feat__t{font-family:var(--mincho);font-weight:500;font-size:18px;margin-bottom:12px;line-height:1.55}
.feat__d{font-size:13px;color:var(--ink-2);line-height:2}
.feat__d b{color:var(--ink);font-weight:500}
/* 長文中の重要フレーズ強調（Saari式・本文アクセント） */
.kw{color:var(--accent);font-weight:700}

/* ---------- terms / 募集要項 ---------- */
.terms{border-top:1px solid var(--ink)}
.terms__row{display:grid;grid-template-columns:1fr;gap:6px;padding:20px 0;border-bottom:1px solid var(--line)}
@media(min-width:680px){.terms__row{grid-template-columns:200px 1fr;gap:28px;align-items:baseline}}
.terms__k{font-family:var(--mincho);font-weight:500;font-size:14px;color:var(--ink)}
.terms__v{font-size:13.5px;color:var(--ink-2);line-height:2}
.terms__v b{color:var(--ink);font-weight:500}

/* ---------- buttons (light sections) ---------- */
.btnrow{display:flex;flex-wrap:wrap;gap:14px}
.btn-fill{background:var(--accent);color:#fff;font-size:13.5px;font-weight:500;letter-spacing:.04em;padding:16px 30px;transition:background .3s}
.btn-fill:hover{background:var(--accent-deep)}
.btn-ghost{border:1px solid var(--ink);color:var(--ink);font-size:13.5px;font-weight:500;letter-spacing:.04em;padding:16px 30px;transition:all .3s}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}

/* ---------- DAILY HIGHLIGHT (③ KINO teaser, top) ---------- */
.daily{background:var(--bg)}
.daily__grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
@media(min-width:760px){.daily__grid{grid-template-columns:repeat(3,1fr)}}
.dcard{background:var(--bg);padding:0}
.dcard__photo{aspect-ratio:4/3;overflow:hidden}
.dcard__photo img{width:100%;height:100%;object-fit:cover}
.dcard__body{padding:22px 24px}
.dcard__meta{font-family:var(--en);font-style:italic;font-size:12px;color:var(--rose-deep);margin-bottom:8px}
.dcard__txt{font-size:13.5px;color:var(--ink);line-height:1.95}
.daily__note{margin-top:20px;font-size:11.5px;color:var(--ink-3);line-height:1.9}

/* ---------- FINAL CTA ---------- */
.final{background:var(--ink-bg);color:var(--paper);text-align:center;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(201,139,134,.18),transparent 60%)}
.final>*{position:relative;z-index:1}
.final h2{font-family:var(--mincho);font-weight:500;font-size:clamp(28px,5vw,60px);line-height:1.4;margin-bottom:20px}
.final h2 em{color:var(--rose)}
.final p{font-size:14.5px;color:var(--paper-2);max-width:34em;margin:0 auto 44px;line-height:2.1}
.final__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.final__btns a{font-size:13.5px;font-weight:500;letter-spacing:.04em;padding:16px 30px;transition:all .3s}
.final__btns a small{display:block;font-size:10.5px;opacity:.7;margin-top:3px;font-weight:300}
.final__btns:has(.final__sub){flex-direction:column;align-items:center}
.final__btns:has(.final__sub)>.b-fill{min-width:260px}
.final__sub{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;max-width:480px}
.final__sub>a{min-width:0;padding-left:14px;padding-right:14px}
.b-fill{background:var(--accent);color:#fff}.b-fill:hover{background:var(--accent-deep)}
.b-line{border:1px solid var(--paper-2);color:var(--paper)}.b-line:hover{background:var(--paper);color:var(--ink-bg)}

/* ---------- footer ---------- */
.foot{background:var(--ink-bg);color:var(--paper-2);padding:64px var(--pad) 36px;border-top:1px solid rgba(255,255,255,.1)}
.foot__top{max-width:1340px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:36px}
@media(min-width:760px){.foot__top{grid-template-columns:1.4fr 1fr 1fr;gap:clamp(32px,5vw,72px)}}
.foot h5{font-family:var(--mincho);font-weight:500;color:var(--paper);font-size:24px;margin-bottom:16px}
.foot h5 .x{color:var(--rose)}
.foot p{font-size:12.5px;line-height:2}
.foot h6{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--paper-2);margin-bottom:14px;font-weight:500}
.foot li{padding:5px 0;font-size:13px}
.foot li a:hover{color:var(--paper)}
.foot__copy{max-width:1340px;margin:48px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--en);font-style:italic;font-size:12px;color:var(--ink-4)}

/* mockup banner（ドラフト用・本番非表示） */
.mb{display:none}

/* ---------- mobile nav (hamburger) ---------- */
.hdr__toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:0;background:transparent;border:0;cursor:pointer;z-index:60}
.hdr__toggle span{display:block;height:1.5px;width:24px;background:var(--ink);transition:transform .3s var(--ease),opacity .25s}
.hdr.scrolled .hdr__toggle span{background:var(--ink)}
@media(min-width:960px){.hdr__toggle{display:none}}
body.menu-open .hdr__toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.menu-open .hdr__toggle span:nth-child(2){opacity:0}
body.menu-open .hdr__toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
body.menu-open{overflow:hidden}
.hdr__menu{position:fixed;inset:0;z-index:55;background:var(--ink-bg);color:var(--paper);display:flex;flex-direction:column;justify-content:center;gap:2px;padding:88px var(--pad) 48px;transform:translateX(100%);transition:transform .42s var(--ease);visibility:hidden}
body.menu-open .hdr__menu{transform:none;visibility:visible}
.hdr__menu a{display:block;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.12);color:var(--paper)}
.hdr__menu a .en{display:block;font-family:"Cormorant Garamond","Times New Roman",serif;font-style:normal;font-size:32px;font-weight:400;color:var(--paper);line-height:1.1;letter-spacing:.01em}
.hdr__menu a .ja{display:block;font-family:var(--ja);font-size:12.5px;font-weight:400;color:var(--paper-2);letter-spacing:.1em;margin-top:6px}
.hdr__menu .menu-cta{margin-top:28px;border:0;border-bottom:0;font-family:var(--ja);font-weight:500;font-size:15px;background:var(--accent);color:#fff;padding:18px;text-align:center}
@media(min-width:960px){.hdr__menu{display:none}}
@media(max-width:959px){.hdr__cta{display:none}}

@media(prefers-reduced-motion:reduce){*{animation:none!important}.hdr__menu{transition:none}html{scroll-behavior:auto}}
