/*
Theme Name: KIMIDORI
Theme URI: https://kimidori-inc.com/
Author: KIMIDORI
Description: 株式会社KIMIDORI コーポレートサイト用オリジナルテーマ（障害者雇用の設計・定着・採用支援）。
Version: 1.1
*/

:root{
  /* === KIMIDORI Brand Guide v1.0 準拠 === */
  --white:#FFFFFF; --warm-white:#FAF8F5; --haze:#F0EEEA;
  --sage:#7A9470; --sage-mid:#5E7457; --light-sage:#B0BF96; --sage-soft:#EFF3EC;
  --sakura:#D4949E; --sakura-soft:#F7EAEC; --amber:#E8B87A; --amber-soft:#FBF1E0;
  --ink:#2A2420; --ink-soft:#6E675F; --line:#E6E2DA;
  --font-display:'Outfit',sans-serif;
  --font-head:'Shippori Mincho',serif;
  --font-body:'DM Sans','Noto Sans JP',system-ui,sans-serif;
  --font-mono:'DM Mono',monospace;
  --maxw:1160px;
  color-scheme:light;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--white);line-height:1.9;font-weight:400;-webkit-font-smoothing:antialiased;font-size:16px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 34px}
.eyebrow{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--sage);font-weight:500}
h1,h2,h3{font-family:var(--font-head);font-weight:600;line-height:1.5;color:var(--ink);letter-spacing:.01em}
.lede{color:var(--ink-soft);font-size:1.05rem;line-height:2}

/* logo — Outfit ExtraLight 200, lowercase, tracking .14em */
.logo{font-family:var(--font-display);font-weight:200;font-size:1.5rem;letter-spacing:.14em;color:var(--ink)}
.logo.on-dark{color:var(--white)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--font-body);font-size:.9rem;font-weight:500;letter-spacing:.03em;padding:13px 28px;border-radius:3px;border:1px solid var(--sage);background:var(--sage);color:#fff;transition:all .25s cubic-bezier(.2,.7,.3,1);cursor:pointer}
.btn:hover{background:var(--sage-mid);border-color:var(--sage-mid);color:#fff}
.btn .ar{transition:transform .25s}
.btn:hover .ar{transform:translateX(4px)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn.ghost:hover{border-color:var(--ink);background:transparent;color:var(--ink)}
.btn.lg{padding:16px 34px;font-size:.95rem}
.btn.on-dark{background:var(--warm-white);color:var(--ink);border-color:var(--warm-white)}
.btn.on-dark:hover{background:#fff;border-color:#fff;color:var(--ink)}

/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:78px}
.navlinks{display:flex;align-items:center;gap:38px}
.navlinks a{font-size:.85rem;color:var(--ink);letter-spacing:.04em;transition:color .2s}
.navlinks a:hover{color:var(--sage-mid)}
/* CTAボタンは常に白文字（ホバーでも不可視化しない） */
.navlinks a.btn,.navlinks a.btn:hover{color:#fff}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;color:var(--ink)}

/* HERO — white-dominant, airy */
.hero{background:var(--warm-white);position:relative;overflow:hidden;padding:120px 0 116px}
.hero::after{content:"";position:absolute;right:-160px;top:-160px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,var(--sage-soft),transparent 68%);opacity:.7;pointer-events:none}
.hero .wrap{position:relative}
.hero .rule{width:46px;height:2px;background:var(--sakura);margin-bottom:30px}
.hero .eyebrow{margin-bottom:24px;display:block}
.hero h1{font-size:clamp(2.1rem,5vw,3.6rem);line-height:1.5;letter-spacing:.02em;max-width:15em;font-weight:600}
.hero h1 .em{position:relative;white-space:nowrap}
.hero h1 .em::after{content:"";position:absolute;left:-.02em;right:-.02em;bottom:.06em;height:.16em;background:var(--sakura);opacity:.45;z-index:-1}
.hero .tagline{font-family:var(--font-head);font-size:1.18rem;color:var(--sage-mid);margin-top:34px;font-weight:500}
.hero .sub{max-width:39em;margin-top:18px;color:var(--ink-soft);font-size:1.05rem}
.hero .cta-row{display:flex;gap:14px;margin-top:42px;flex-wrap:wrap}
.hero-meta{position:absolute;right:34px;bottom:30px;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.2em;color:var(--ink-soft);opacity:.55}

/* sections */
section{padding:108px 0}
.sec-warm{background:var(--warm-white)}
.sec-head{max-width:50em}
.sec-head .ix{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;color:var(--ink-soft);display:block;margin-bottom:20px}
.sec-head h2{font-size:clamp(1.65rem,3.4vw,2.4rem);line-height:1.5}
.sec-head .lede{margin-top:22px}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);margin-top:60px;border-top:1px solid var(--line)}
.pillar{padding:40px 34px 40px 0;border-bottom:1px solid var(--line)}
.pillar+.pillar{border-left:1px solid var(--line);padding-left:34px}
.pillar .no{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;color:var(--sage);margin-bottom:22px;display:block}
.pillar h3{font-size:1.32rem;margin-bottom:14px}
.pillar p{font-size:.94rem;color:var(--ink-soft);line-height:1.95}
.notpill{margin-top:46px;font-family:var(--font-head);color:var(--ink);font-size:1.18rem;line-height:1.85;padding-left:20px;border-left:2px solid var(--sakura)}

/* philosophy */
.philo{padding:128px 0}
.philo .inner{max-width:39em}
.philo .eyebrow{color:var(--sage)}
.philo .rule{width:46px;height:2px;background:var(--sakura);margin:24px 0 0}
.philo h2{font-size:clamp(1.8rem,4vw,2.7rem);line-height:1.6;margin:26px 0 32px;font-weight:600}
.philo p{color:var(--ink-soft);font-size:1.08rem;line-height:2.1}
.philo p+p{margin-top:18px}

/* services */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:38px;margin-top:60px}
.svc .card{padding-top:26px;border-top:2px solid var(--sage)}
.svc .card:nth-child(2){border-top-color:var(--amber)}
.svc .card:nth-child(3){border-top-color:var(--sakura)}
.svc .num{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase}
.svc h3{font-size:1.24rem;margin:14px 0 12px}
.svc p{font-size:.94rem;color:var(--ink-soft);line-height:1.95}

/* column — siro風カード（日付＋カテゴリ＋タイトル＋抜粋） */
.col-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.col-nav{display:flex;align-items:center;gap:10px}
.col-arrow{width:46px;height:46px;border:1px solid var(--line);background:var(--white);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:all .2s}
.col-arrow svg{width:18px;height:18px}
.col-arrow:hover{border-color:var(--sage);color:var(--sage-mid)}
.col-arrow:disabled{opacity:.3;cursor:default;border-color:var(--line);color:var(--ink)}
.col-carousel{position:relative}
/* Splide風カルーセル：デスクトップは3枚＋次の覗き、矢印で送る */
.col-grid{display:flex;gap:28px;margin-top:54px;overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain;touch-action:pan-x;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.col-grid::-webkit-scrollbar{display:none}
.post{flex:0 0 30%;scroll-snap-align:start;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);transition:border-color .25s,transform .25s,box-shadow .25s}
.post:hover{border-color:var(--sage);transform:translateY(-4px);box-shadow:0 18px 40px rgba(42,36,32,.07)}
.post .thumb{aspect-ratio:16/10;display:flex;align-items:flex-end;padding:20px 22px}
.post .thumb.t1{background:var(--sage-soft)}
.post .thumb.t2{background:var(--amber-soft)}
.post .thumb.t3{background:var(--sakura-soft)}
.post .thumb .ph{font-family:var(--font-head);font-weight:700;font-size:1.4rem;color:var(--ink);opacity:.82;letter-spacing:.02em}
.post .pbody{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.post .pmeta{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.post .pmeta .date{font-family:var(--font-mono);font-size:.7rem;color:var(--ink-soft);letter-spacing:.06em}
.tag{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-mid);border:1px solid var(--line);padding:3px 10px;border-radius:2px}
.post h3{font-size:1.08rem;line-height:1.65;margin-bottom:12px}
.post p{font-size:.86rem;color:var(--ink-soft);flex:1;line-height:1.9}
.post .more{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--sage-mid);margin-top:22px;display:inline-flex;gap:7px;align-items:center}
.post .more .ar{transition:transform .25s}
.post:hover .more .ar{transform:translateX(4px)}
.swipe-hint{display:none;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;color:var(--ink-soft);margin-top:16px;text-align:center}
/* カルーセルのページ位置インジケーター（モバイルのみ表示） */
.col-dots{display:none}

/* group */
.grp{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.grp .g{padding:36px 30px;border:1px solid var(--line);transition:border-color .25s}
.grp .g:hover{border-color:var(--sage)}
.grp .g.kimi{background:var(--sage);border-color:var(--sage)}
.grp .g .lg{font-family:var(--font-display);font-weight:200;letter-spacing:.16em;font-size:1.5rem;margin-bottom:16px;color:var(--ink)}
.grp .g.kimi .lg{color:#fff}
.grp .g p{font-size:.9rem;color:var(--ink-soft);line-height:1.9}
.grp .g.kimi p{color:rgba(255,255,255,.92)}

/* CTA band — On Sage（濃色は黒でなく緑面に） */
.cta-band{background:var(--sage);color:#fff;padding:90px 64px;text-align:center;position:relative}
.cta-band .rule{width:46px;height:2px;background:var(--sakura);margin:0 auto 22px}
.cta-band .eyebrow{color:rgba(255,255,255,.88)}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,3.4vw,2.3rem);margin:16px auto 16px;max-width:22em;line-height:1.6}
.cta-band p{color:rgba(255,255,255,.9);max-width:34em;margin:0 auto 34px;font-size:1rem;line-height:1.95}

/* company */
.about-grid{margin-top:46px;border-top:1px solid var(--line)}
.about-grid .row{display:grid;grid-template-columns:220px 1fr;gap:24px;padding:22px 4px;border-bottom:1px solid var(--line)}
.about-grid .k{font-weight:500;color:var(--ink);font-size:.84rem;font-family:var(--font-mono);letter-spacing:.04em}
.about-grid .v{color:var(--ink-soft);font-size:.96rem}
.todo{color:var(--amber);font-family:var(--font-mono);font-size:.78rem}
.map{margin-top:40px;border:1px solid var(--line);aspect-ratio:16/6;overflow:hidden}
.map iframe{width:100%;height:100%;border:0;display:block}

/* footer — Warm White（黒を大面積で使わない） */
footer{background:var(--warm-white);color:var(--ink-soft);padding:74px 0 34px;border-top:1px solid var(--line)}
footer .ft-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
footer .logo{color:var(--ink)}
footer .ft-tag{font-family:var(--font-head);color:var(--sage-mid);font-size:1rem;margin-top:18px}
footer .ft-links{display:flex;gap:56px;flex-wrap:wrap}
footer .ft-col h4{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:500;margin-bottom:16px}
footer .ft-col a{display:block;font-size:.86rem;margin-bottom:10px;color:var(--ink-soft);transition:color .2s}
footer .ft-col a:hover{color:var(--ink)}
footer .copy{margin-top:56px;padding-top:26px;border-top:1px solid var(--line);font-size:.72rem;color:var(--ink-soft);font-family:var(--font-mono);letter-spacing:.05em}

/* issues — お悩みブロック */
.issues{background:var(--sage-soft)}
.issue-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:48px}
.issue{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--line);padding:24px 26px}
.issue .q{font-family:var(--font-head);font-weight:700;color:var(--sage);font-size:1.5rem;line-height:1;flex:none}
.issue p{font-size:.98rem;color:var(--ink);line-height:1.8}
.issue p strong{font-weight:600}
.issue-bridge{margin-top:38px;font-family:var(--font-head);font-size:1.24rem;color:var(--ink);line-height:1.85}
.issue-bridge .em{color:var(--sage-mid)}
.issue-bridge .lnk{display:inline-flex;gap:7px;align-items:center;margin-top:18px;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.06em;color:var(--sage-mid)}
.issue-bridge .lnk .ar{transition:transform .25s}
.issue-bridge .lnk:hover .ar{transform:translateX(4px)}

/* service menu — 具体4メニュー */
.menu{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:54px}
.menu .m{border:1px solid var(--line);padding:30px;background:var(--white);transition:border-color .25s,transform .25s}
.menu .m:hover{border-color:var(--sage);transform:translateY(-3px)}
.menu .badge{display:inline-block;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:4px 11px;border-radius:2px;margin-bottom:16px;border:1px solid var(--line);color:var(--sage-mid)}
.menu .m:nth-child(1) .badge{color:#fff;background:var(--sage);border-color:var(--sage)}
.menu .m:nth-child(2) .badge{color:var(--ink);background:var(--amber-soft);border-color:var(--amber)}
.menu .m:nth-child(3) .badge{color:var(--sakura);background:var(--sakura-soft);border-color:var(--sakura)}
.menu .m:nth-child(4) .badge{color:var(--sage-mid)}
.menu h3{font-size:1.2rem;margin-bottom:10px}
.menu p{font-size:.92rem;color:var(--ink-soft);line-height:1.9}

/* flow */
.flow{display:flex;margin-top:40px;border:1px solid var(--line)}
.flow .step{flex:1;padding:26px 24px}
.flow .step+.step{border-left:1px solid var(--line)}
.flow .step .n{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;color:var(--sage);margin-bottom:10px;display:block}
.flow .step h4{font-family:var(--font-head);font-weight:600;font-size:1.08rem;margin-bottom:6px}
.flow .step p{font-size:.85rem;color:var(--ink-soft);line-height:1.8}

/* one-stop phases — persol参考のワンストップ支援フェーズ図 */
.onestop{margin-top:64px;border-top:1px solid var(--line);padding-top:48px}
.onestop .os-head{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;color:var(--ink-soft);text-transform:uppercase;display:block;margin-bottom:10px}
.onestop h3{font-size:1.3rem;margin-bottom:12px}
.onestop .os-lead{color:var(--ink-soft);font-size:.98rem;line-height:1.9;max-width:46em;margin-bottom:38px}
.phases{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.phase{border:1px solid var(--line);background:var(--white);padding:26px 22px;position:relative}
.phase .pn{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;color:var(--sage);display:block;margin-bottom:14px}
.phase h4{font-family:var(--font-head);font-weight:600;font-size:1.12rem;margin-bottom:14px}
.phase ul{list-style:none;margin:0;padding:0}
.phase li{position:relative;padding-left:16px;font-size:.86rem;color:var(--ink-soft);line-height:1.7;margin-bottom:8px}
.phase li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;border-radius:50%;background:var(--sage)}
.phase+.phase::before{content:"›";position:absolute;left:-13px;top:50%;transform:translateY(-50%);color:var(--ink-soft);font-size:1.1rem;line-height:1}

/* internship band */
.intern{border:1px solid var(--line);background:var(--warm-white);padding:46px 48px}
.intern .eyebrow{color:var(--sage)}
.intern h3{font-size:1.42rem;margin:14px 0 16px;line-height:1.55}
.intern p{font-size:1rem;color:var(--ink-soft);line-height:1.95;max-width:46em}
.intern .disc{margin-top:20px;font-size:.8rem;color:var(--ink-soft);font-family:var(--font-mono);letter-spacing:.01em;line-height:1.75;padding-left:16px;border-left:2px solid var(--light-sage)}

/* solution list — サービス（persol参考のソリューション一覧） */
.sol-list{margin-top:58px;border-top:1px solid var(--line)}
.sol{display:grid;grid-template-columns:60px 1fr 150px;gap:30px;align-items:start;padding:32px 6px;border-bottom:1px solid var(--line);transition:background .25s}
.sol:hover{background:var(--warm-white)}
.sol .no{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.1em;color:var(--sage);padding-top:5px}
.sol .body h3{font-size:1.3rem;margin-bottom:10px}
.sol .body p{font-size:.95rem;color:var(--ink-soft);line-height:1.9;max-width:40em}
.sol .badge{justify-self:end;white-space:nowrap;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;padding:5px 12px;border:1px solid var(--line);border-radius:2px;color:var(--sage-mid);margin-top:4px}
.sol:first-child .badge{color:#fff;background:var(--sage);border-color:var(--sage)}

/* group mini — siro/aoは小さく一行で（KIMIDORIを主役に） */
.group-mini{margin-top:42px;padding-top:26px;border-top:1px solid var(--line);display:flex;align-items:baseline;gap:22px;flex-wrap:wrap}
.group-mini .gm-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.group-mini .gm{display:inline-flex;align-items:baseline;gap:10px}
.group-mini .gm .gnm{font-family:var(--font-display);font-weight:200;letter-spacing:.14em;font-size:1.18rem;color:var(--ink);transition:color .2s}
.group-mini .gm .d{font-size:.86rem;color:var(--ink-soft)}
.group-mini a.gm .ext{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-soft);transition:color .2s}
.group-mini a.gm:hover .gnm,.group-mini a.gm:hover .ext{color:var(--sage-mid)}
.group-mini .sep{color:var(--line)}

/* reveal */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.js .reveal.in{opacity:1;transform:none}

@media (max-width:880px){
  .nav-in{height:72px}
  .navlinks{position:fixed;inset:72px 0 auto 0;flex-direction:column;background:var(--warm-white);border-bottom:1px solid var(--line);padding:22px 34px 30px;gap:22px;align-items:flex-start;display:none}
  .navlinks.open{display:flex}
  .navlinks a{font-size:1rem}
  .menu-toggle{display:block}
  .hero{padding:88px 0 80px}
  .hero-meta{display:none}
  .pillars,.svc,.grp,.issue-grid,.menu{grid-template-columns:1fr}
  .flow{flex-direction:column}
  .flow .step+.step{border-left:0;border-top:1px solid var(--line)}
  .phases{grid-template-columns:1fr;gap:30px}
  .phase+.phase::before{content:"↓";left:50%;top:-21px;transform:translateX(-50%)}
  .intern{padding:32px 26px}
  .pillar+.pillar{border-left:0;padding-left:0}
  .sol{grid-template-columns:1fr;gap:8px;padding:26px 4px}
  .sol .no{padding-top:0}
  .sol .badge{justify-self:start;margin-top:8px}
  .group-mini{flex-direction:column;align-items:flex-start;gap:12px}
  .group-mini .sep{display:none}
  .col-arrow{display:none}
  .pillar{padding:32px 0}
  .cta-band{padding:60px 28px}
  section{padding:72px 0}
  .philo{padding:80px 0}
  .about-grid .row{grid-template-columns:120px 1fr;gap:14px}
  .map{aspect-ratio:4/3}

  /* blog cards -> 横スワイプ・カルーセル（siro踏襲：次カードを覗かせる peek 型） */
  .col-grid{display:flex;grid-template-columns:none;list-style:none;
    gap:16px;
    padding:8px 34px 34px;            /* 左右ガター=ページ余白 / 下は影のぶん確保 */
    margin:54px -34px 0;              /* 画面端までフルブリード */
    overflow-x:auto;overflow-y:hidden;          /* 縦スクロールを無効化 */
    overscroll-behavior-x:contain;
    touch-action:pan-x;               /* 縦スワイプはページ側へ通す（流れを止めない） */
    scroll-snap-type:x mandatory;
    scroll-padding-inline-start:34px; /* スナップ位置をガターに合わせる */
    -webkit-overflow-scrolling:touch;scrollbar-width:none}
  .col-grid::-webkit-scrollbar{display:none}
  .post{flex:0 0 calc(100vw - 132px); /* 次カードを大きめ(約80px)に覗かせる */
    width:auto;min-width:0;
    scroll-snap-align:start;scroll-snap-stop:always;
    border-color:#CFC8B9;             /* 覗くカードの左端を線で明示（淡サムネ対策） */
    box-shadow:0 12px 30px rgba(42,36,32,.10)}
  .swipe-hint{display:none}
  /* ページ位置ドット */
  .col-dots{display:flex;justify-content:center;gap:8px;margin-top:22px}
  .col-dots span{width:7px;height:7px;border-radius:50%;background:var(--line);transition:width .25s,background .25s}
  .col-dots span.on{background:var(--sage);width:22px;border-radius:4px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.js .reveal{opacity:1;transform:none}html{scroll-behavior:auto}}


/* ===== コラム記事ページ（single-column） ===== */
.arthead{background:var(--warm-white);padding:64px 0 14px;border-bottom:1px solid var(--line)}
.crumb{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;color:var(--ink-soft);margin-bottom:24px}
.crumb a:hover{color:var(--sage-mid)}
.artwrap{max-width:740px;margin:0 auto;padding:0 34px}
.arthead .tag{display:inline-block;font-family:var(--font-mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-mid);border:1px solid var(--line);background:#fff;padding:5px 12px;border-radius:2px;margin-bottom:20px}
h1.title{font-family:var(--font-head);font-weight:700;font-size:clamp(1.7rem,3.8vw,2.5rem);line-height:1.55;letter-spacing:.01em}
.arthead .meta{display:flex;align-items:center;gap:16px;margin-top:26px;padding-bottom:30px;color:var(--ink-soft);font-size:.8rem;font-family:var(--font-mono);letter-spacing:.04em}
.arthead .meta .au{display:flex;align-items:center;gap:9px;color:var(--ink)}
article.post-body{max-width:740px;margin:0 auto;padding:52px 34px 10px}
article.post-body p{margin:0 0 24px;font-size:1.05rem;line-height:2.1}
article.post-body h2{font-family:var(--font-head);font-weight:600;font-size:1.5rem;margin:52px 0 18px;line-height:1.5}
article.post-body h2::before{content:"";display:block;width:34px;height:2px;background:var(--sakura);margin-bottom:18px}
article.post-body h3{font-family:var(--font-head);font-weight:600;font-size:1.18rem;margin:32px 0 12px;color:var(--sage-mid)}
article.post-body ul{margin:0 0 24px;padding-left:0;list-style:none}
article.post-body li{position:relative;padding-left:22px;margin-bottom:14px;font-size:1.02rem;line-height:1.95}
article.post-body li::before{content:"";position:absolute;left:0;top:.72em;width:7px;height:7px;border-radius:50%;background:var(--sage)}
article.post-body blockquote{border-left:3px solid var(--sakura);padding:8px 0 8px 28px;margin:38px 0;font-family:var(--font-head);font-size:1.32rem;color:var(--ink);line-height:1.7;font-weight:600}
.note{background:var(--warm-white);border:1px solid var(--line);border-radius:4px;padding:18px 22px;margin:30px 0;font-size:.92rem;color:var(--ink-soft);line-height:1.9}
.endcta{max-width:740px;margin:48px auto 80px;padding:0 34px}
.endcta .box{background:var(--sage);color:#fff;padding:56px 44px;text-align:center;position:relative}
.endcta .box .rule{width:46px;height:2px;background:var(--sakura);margin:0 auto 20px}
.endcta h3{font-family:var(--font-head);color:#fff;font-size:1.35rem;margin-bottom:12px;line-height:1.55}
.endcta p{color:rgba(255,255,255,.9);font-size:.96rem;margin-bottom:26px;line-height:1.95}
.endcta .btn{background:var(--warm-white);color:var(--ink);border-color:var(--warm-white)}
.endcta .btn:hover{background:#fff;border-color:#fff}
.pager{max-width:740px;margin:40px auto 0;padding:0 34px;display:flex;justify-content:center}


/* ===== アイキャッチ画像（カードサムネ／記事冒頭） ===== */
.post .thumb{overflow:hidden}
.post .thumb.has-img{padding:0;display:block}
.post .thumb .thumb-img,.post .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.art-hero{max-width:740px;margin:36px auto 0;padding:0 34px}
.art-hero img{width:100%;height:auto;display:block}
@media (max-width:880px){ .art-hero{margin-top:24px} }
