@charset "UTF-8";
/* 研修詳細ページ（single-menu_post.php）専用スタイル
   ACFテンプレート化対応。全セレクタを .p-training-detail 配下にスコープしてテーマ全体への影響を防止 */

.p-training-detail{
  --ink:#14110f;--ink-soft:#3a3632;--paper:#f7f3ee;--cream:#efe9e1;--cream2:#e8e0d5;
  --accent:#1a3a52;--accent-light:#2a5a7a;--gold:#e8d9b8;--gold-dark:#c4a870;--muted:#8a847c;
  --serif:'Noto Serif JP',serif;--sans:'Noto Sans JP',sans-serif;--mono:'Space Mono',monospace;
  --radius:10px;
  font-family:var(--serif);background:var(--paper);color:var(--ink);line-height:1.8;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.p-training-detail *,.p-training-detail *::before,.p-training-detail *::after{margin:0;padding:0;box-sizing:border-box}
.p-training-detail a{color:inherit;text-decoration:none}
.p-training-detail [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.p-training-detail [data-reveal].visible{opacity:1;transform:translateY(0)}

/* S1: Compact Header */
.p-training-detail .header{background:var(--ink);color:var(--paper);padding:120px 40px 80px;position:relative}
.p-training-detail .header-inner{max-width:800px;margin:0 auto}
.p-training-detail .breadcrumb{font-family:var(--sans);font-size:11px;color:var(--muted);margin-bottom:28px}
.p-training-detail .breadcrumb a{color:var(--gold);transition:color .2s}
.p-training-detail .breadcrumb a:hover{color:#f0e4c8}
.p-training-detail .header-label{font-family:var(--mono);font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.p-training-detail .header-catch{font-family:var(--serif);font-size:clamp(22px,3.5vw,36px);font-weight:700;line-height:1.4;margin-bottom:12px;background:linear-gradient(135deg,var(--gold),#f0e4c8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.p-training-detail .header h1{font-family:var(--serif);font-size:clamp(18px,2.5vw,26px);font-weight:600;line-height:1.3;margin-bottom:20px;color:rgba(247,243,238,.7)}
.p-training-detail .header-sub{font-family:var(--sans);font-size:clamp(13px,1.4vw,15px);color:rgba(247,243,238,.6);line-height:2;margin-bottom:28px;max-width:600px}
.p-training-detail .header-tags{display:flex;gap:8px;flex-wrap:wrap}
.p-training-detail .header-tag{padding:5px 14px;border:1px solid rgba(232,217,184,.2);border-radius:20px;font-family:var(--sans);font-size:11px;color:var(--gold)}

/* Section utilities */
.p-training-detail .sec{padding:80px 40px}
.p-training-detail .sec-inner{max-width:740px;margin:0 auto}
.p-training-detail .sec-label{font-family:var(--mono);font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.p-training-detail .sec-title{font-family:var(--serif);font-size:clamp(20px,2.8vw,28px);font-weight:700;margin-bottom:24px}
.p-training-detail .sec-title em{font-style:normal;color:var(--accent)}
.p-training-detail .sec-lead{font-family:var(--sans);font-size:13px;color:var(--ink-soft);line-height:1.8;margin-bottom:28px}

/* S2: Core text */
.p-training-detail .core-text{font-family:var(--sans);font-size:15px;color:var(--ink-soft);line-height:2.2;text-align:center;max-width:580px;margin:0 auto}
.p-training-detail .core-text p+p{margin-top:16px}
.p-training-detail .core-text strong{color:var(--ink);font-weight:600}

/* Perspective cards */
.p-training-detail .perspective-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
.p-training-detail .perspective-card{padding:28px 24px;background:var(--cream);border-radius:var(--radius);display:flex;flex-direction:column}
.p-training-detail .perspective-num{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.15em;margin-bottom:10px}
.p-training-detail .perspective-card h3{font-family:var(--serif);font-size:16px;font-weight:700;line-height:1.4;margin-bottom:10px;color:var(--ink)}
.p-training-detail .perspective-card p{font-family:var(--sans);font-size:13px;color:var(--ink-soft);line-height:1.9}

/* Coverage tags */
.p-training-detail .coverage-tags{display:flex;flex-wrap:wrap;gap:6px}
.p-training-detail .coverage-tags span{padding:4px 12px;border:1px solid var(--cream2);border-radius:20px;font-family:var(--sans);font-size:11px;color:var(--ink-soft);background:#fff}

/* S3: Before/After */
.p-training-detail .ba-grid{display:flex;flex-direction:column;gap:20px}
.p-training-detail .ba-item{display:grid;grid-template-columns:1fr 36px 1fr;align-items:stretch;border:1px solid var(--cream2);border-radius:var(--radius);overflow:hidden;background:#fff}
.p-training-detail .ba-side{padding:20px 18px;font-family:var(--sans);font-size:13px;line-height:1.8}
.p-training-detail .ba-before{background:rgba(20,17,15,.02);color:var(--ink-soft)}
.p-training-detail .ba-after{color:var(--accent);font-weight:500}
.p-training-detail .ba-arrow{display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;font-size:14px;font-weight:700}
.p-training-detail .ba-tag{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;display:block;margin-bottom:4px}
.p-training-detail .ba-before .ba-tag{color:var(--muted)}
.p-training-detail .ba-after .ba-tag{color:var(--gold-dark)}

/* S4: Timeline */
.p-training-detail .tl{position:relative;padding-left:40px}
.p-training-detail .tl::before{content:'';position:absolute;left:8px;top:4px;bottom:10px;width:2px;background:linear-gradient(180deg,var(--gold-dark),var(--accent) 55%,rgba(26,58,82,.15))}
.p-training-detail .tl-divider{position:relative;font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--accent);font-weight:700;margin:38px 0 20px;padding-left:14px}
.p-training-detail .tl-divider:first-child{margin-top:0}
.p-training-detail .tl-divider::before{content:'';position:absolute;left:-40px;top:50%;width:19px;height:19px;border-radius:50%;background:var(--cream);border:2px solid var(--gold-dark);transform:translateY(-50%)}
.p-training-detail .tl-divider::after{content:'';position:absolute;left:-33px;top:50%;width:5px;height:5px;border-radius:50%;background:var(--gold-dark);transform:translateY(-50%)}
.p-training-detail .tl-item{position:relative;margin-bottom:18px;padding:16px 20px;background:#fff;border:1px solid var(--cream2);border-radius:var(--radius);box-shadow:0 1px 3px rgba(20,17,15,.04);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}
.p-training-detail .tl-item:hover{transform:translateX(5px);border-color:var(--accent);box-shadow:0 10px 26px rgba(20,17,15,.09)}
.p-training-detail .tl-item::before{content:'';position:absolute;left:-37px;top:20px;width:12px;height:12px;border-radius:50%;background:var(--gold-dark);border:3px solid var(--cream);box-shadow:0 0 0 2px var(--gold-dark);transition:all .3s ease}
.p-training-detail .tl-item:hover::before{background:var(--accent);box-shadow:0 0 0 2px var(--accent),0 0 12px rgba(26,58,82,.35)}
.p-training-detail .tl-time{display:inline-block;font-family:var(--mono);font-size:11px;color:var(--accent);font-weight:700;letter-spacing:.05em;background:rgba(26,58,82,.07);padding:3px 12px;border-radius:20px;margin-bottom:9px}
.p-training-detail .tl-name{font-family:var(--serif);font-size:15.5px;font-weight:700;margin-bottom:5px;line-height:1.5}
.p-training-detail .tl-desc{font-family:var(--sans);font-size:13px;color:var(--ink-soft);line-height:1.85}
.p-training-detail .tl-img{margin:12px 0;border-radius:var(--radius);overflow:hidden}
.p-training-detail .tl-img img{display:block;max-width:100%;border-radius:var(--radius)}
.p-training-detail .tl-img-placeholder{margin:12px 0;padding:40px 20px;background:var(--cream);border-radius:var(--radius);border:1px dashed var(--cream2);text-align:center;font-family:var(--mono);font-size:11px;color:var(--muted)}

/* S5: Accordion */
.p-training-detail .acc-item{border-bottom:1px solid var(--cream2);overflow:hidden}
.p-training-detail .acc-item:first-child{border-top:1px solid var(--cream2)}
.p-training-detail .acc-q{display:flex;align-items:center;justify-content:space-between;padding:18px 0;cursor:pointer;gap:16px}
.p-training-detail .acc-q:hover .acc-title{color:var(--accent)}
.p-training-detail .acc-title{font-family:var(--serif);font-size:15px;font-weight:600;transition:color .2s}
.p-training-detail .acc-sub{font-family:var(--sans);font-size:12px;color:var(--ink-soft);line-height:1.7;margin-top:2px}
.p-training-detail .acc-arrow{font-size:14px;color:var(--muted);transition:transform .3s;flex-shrink:0}
.p-training-detail .acc-item.open .acc-arrow{transform:rotate(180deg)}
.p-training-detail .acc-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.p-training-detail .acc-item.open .acc-a{max-height:600px}
.p-training-detail .acc-a-inner{padding:0 0 18px;font-family:var(--sans);font-size:13px;color:var(--ink-soft);line-height:1.9}
.p-training-detail .acc-a-inner p{margin-bottom:4px}

/* S6: Overview table */
.p-training-detail .ov-table{width:100%;border-collapse:collapse}
.p-training-detail .ov-table tr{border-bottom:1px solid var(--cream2)}
.p-training-detail .ov-table th{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--accent);padding:14px 16px 14px 0;text-align:left;vertical-align:top;white-space:nowrap;width:100px}
.p-training-detail .ov-table td{font-family:var(--sans);font-size:13px;color:var(--ink-soft);padding:14px 0;line-height:1.7}

/* S7: CTA compact */
.p-training-detail .cta-compact{padding:80px 40px;background:var(--ink);color:var(--paper);text-align:center}
.p-training-detail .cta-compact-inner{max-width:560px;margin:0 auto}
.p-training-detail .cta-compact h2{font-family:var(--serif);font-size:clamp(20px,3vw,28px);font-weight:700;margin-bottom:16px}
.p-training-detail .cta-compact p{font-family:var(--sans);font-size:14px;color:rgba(247,243,238,.6);line-height:1.9;margin-bottom:28px}
.p-training-detail .cta-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 36px;border-radius:40px;font-size:14px;font-weight:600;font-family:var(--sans);transition:all .3s ease;background:var(--gold);color:var(--ink)}
.p-training-detail .cta-btn:hover{background:#f0e4c8;transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,217,184,.25)}
.p-training-detail .cta-links{margin-top:20px;font-family:var(--sans);font-size:12px;color:var(--muted);line-height:2}
.p-training-detail .cta-links a{color:var(--gold);text-decoration:underline}

/* S8: Related */
.p-training-detail .rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.p-training-detail .rel-card{padding:24px 20px;background:#fff;border:1px solid var(--cream2);border-radius:var(--radius);transition:all .3s ease}
.p-training-detail .rel-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.p-training-detail .rel-card h3{font-family:var(--serif);font-size:14px;font-weight:600;margin-bottom:6px}
.p-training-detail .rel-card p{font-family:var(--sans);font-size:12px;color:var(--ink-soft);line-height:1.7;margin-bottom:8px}
.p-training-detail .rel-card a{font-family:var(--sans);font-size:11px;color:var(--accent);font-weight:500}

@media(max-width:768px){
  .p-training-detail .header{padding:100px 24px 60px}
  .p-training-detail .sec{padding:60px 24px}
  .p-training-detail .ba-item{grid-template-columns:1fr;gap:0}
  .p-training-detail .ba-arrow{padding:8px;font-size:12px}
  .p-training-detail .rel-grid{grid-template-columns:1fr}
  .p-training-detail .cta-compact{padding:60px 24px}
  .p-training-detail .ov-table th{width:80px;font-size:11px}
  .p-training-detail .perspective-grid{grid-template-columns:1fr}
  .p-training-detail .highlight-flex{flex-direction:column}
}
