@charset "UTF-8";
/*
    Template: swell
    Theme Name: STRIKERJP.COM (SWELL Child)
    Theme URI: https://strikerjp.com/
    Description: ストライカードットコム 子テーマ。サイト全体の共通CSSをここに集約。
    Version: 1.1.0
    Author: Mekanista
    Author URI: https://strikerjp.com/
    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* =========================================================
   STRIKERJP.COM 共通CSS（TOP/固定ページ/記事ページ共通）
   ========================================================= */

:root {
  --black:      #0a0a0a;
  --dark:       #111111;
  --dark-mid:   #181818;
  --dark-light: #222222;
  --red:        #d42b2b;
  --red-light:  #ff4444;
  --red-dark:   #a01c1c;
  --white:      #ffffff;
  --off-white:  #f0f0f0;
  --muted:      rgba(255,255,255,.5);
  --gh-h:       64px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP',sans-serif;background:var(--black);color:var(--off-white);overflow-x:hidden;-webkit-text-size-adjust:100%}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}

/* ─── GLOBAL HEADER ─── */
.gh{position:fixed;top:0;left:0;right:0;height:var(--gh-h);z-index:300;background:rgba(10,10,10,.85);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;padding:0 40px}
.gh-logo{display:flex;align-items:center;gap:12px}
.gh-logo-img{height:34px;width:auto}
.gh-logo-txt{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.1rem;letter-spacing:.06em;color:var(--white);text-transform:uppercase}
.gh-nav{display:flex;gap:18px;list-style:none;align-items:center}
.gh-nav a{font-size:.72rem;font-weight:700;letter-spacing:.06em;color:var(--off-white);transition:color .25s;white-space:nowrap}
.gh-nav a:hover{color:var(--red-light)}
.gh-cta{font-size:.7rem;font-weight:700;letter-spacing:.1em;padding:9px 18px;background:var(--red);color:var(--white);transition:all .25s}
.gh-cta:hover{background:var(--red-light);transform:translateY(-1px)}
.gh-hamburger{display:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;background:none;border:none}
.gh-hamburger span{display:block;width:24px;height:2px;background:var(--white);transition:.3s}
.gh-drop{position:relative}
.gh-drop > a::after{content:' ▾';font-size:.6em;opacity:.7;margin-left:2px}
.gh-submenu{position:absolute;top:100%;left:-16px;background:rgba(10,10,10,.96);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.1);padding:10px 0;min-width:220px;list-style:none;display:none}
.gh-drop:hover .gh-submenu{display:block}
.gh-submenu li{margin:0}
.gh-submenu a{display:block;padding:11px 22px;font-size:.72rem;color:var(--off-white);white-space:nowrap;letter-spacing:.06em;font-weight:600}
.gh-submenu a:hover{background:rgba(212,43,43,.15);color:var(--red-light)}
.gh-mega-section{display:flex;flex-direction:column;align-items:center;gap:14px;margin:6px 0}
.gh-mega-section small{font-size:.6rem;letter-spacing:.22em;color:var(--red-light);font-weight:700;text-transform:uppercase}

.main-wrap{padding-top:var(--gh-h)}

/* ─── HERO ─── */
.hero{position:relative;height:calc(100svh - var(--gh-h));min-height:620px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,10,10,.35) 0%,rgba(10,10,10,.55) 60%,rgba(10,10,10,.95) 100%)}
.hero-copy{position:absolute;left:56px;right:56px;bottom:96px;z-index:10;max-width:820px}
.hero-eyebrow{display:inline-block;font-family:'Noto Sans JP','Barlow Condensed',sans-serif;font-weight:700;font-size:.95rem;letter-spacing:.14em;color:var(--red-light);margin-bottom:20px}
.hero-title{font-weight:900;font-size:clamp(2rem,5.2vw,4.2rem);line-height:1.18;color:var(--white);margin-bottom:18px;letter-spacing:-.01em}
.hero-sub{font-size:clamp(.85rem,1.4vw,1.05rem);color:rgba(255,255,255,.82);font-weight:500;line-height:1.8;max-width:560px;margin-bottom:28px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{font-weight:700;font-size:.78rem;letter-spacing:.12em;text-decoration:none;padding:14px 28px;transition:all .3s;display:inline-block}
.btn-red{background:var(--red);color:var(--white);clip-path:polygon(0 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%)}
.btn-red:hover{background:var(--red-light);transform:translateY(-2px)}
.btn-outline{border:1px solid rgba(255,255,255,.35);color:var(--white)}
.btn-outline:hover{border-color:var(--red-light);color:var(--red-light)}
.hero-progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,.1);z-index:20}
.hero-progress-bar{height:100%;background:var(--red);width:0;transition:width .1s linear}
.hero-nav{position:absolute;bottom:32px;right:56px;z-index:20;display:flex;gap:10px}
.hero-nav-btn{width:42px;height:42px;border:1px solid rgba(255,255,255,.3);background:rgba(10,10,10,.35);color:var(--white);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .25s}
.hero-nav-btn:hover{border-color:var(--red-light);color:var(--red-light)}

/* ─── SECTION COMMON ─── */
.sec-label{font-size:.68rem;font-weight:700;letter-spacing:.2em;color:var(--red-light);margin-bottom:14px;display:flex;align-items:center;gap:10px;font-family:'Barlow Condensed',sans-serif;text-transform:uppercase}
.sec-label::before{content:'';width:28px;height:1px;background:var(--red);flex-shrink:0}
.sec-title{font-weight:900;font-size:clamp(1.8rem,4vw,3rem);line-height:1.25;color:var(--white)}
.sec-desc{margin-top:16px;font-size:.85rem;color:var(--muted);max-width:560px;line-height:1.9}
.section-divider{height:1px;background:linear-gradient(to right,transparent,rgba(212,43,43,.25),transparent)}

/* ─── PHASE1 ESCAPE ─── */
.escape-section{padding:96px 56px;background:var(--black);position:relative;overflow:hidden}
.escape-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:18vw;color:rgba(212,43,43,.025);white-space:nowrap;pointer-events:none}
.escape-inner{max-width:1240px;margin:0 auto;position:relative;z-index:2}
.escape-header{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end;margin-bottom:44px}
.escape-cta-wrap{text-align:right}
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);margin:0 0 40px}
.stat-cell{background:var(--dark-mid);padding:26px 16px;text-align:center}
.stat-num{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:2.6rem;line-height:1;color:var(--red-light)}
.stat-num.white{color:var(--white)}
.stat-sub{font-size:.58rem;letter-spacing:.15em;color:var(--muted);margin-top:6px;font-weight:500}
.region-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:28px;flex-wrap:wrap}
.region-tab{font-size:.75rem;font-weight:700;letter-spacing:.08em;color:var(--muted);background:none;border:none;padding:12px 20px 14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .25s}
.region-tab.active{color:var(--red-light);border-bottom-color:var(--red)}
.region-tab:hover:not(.active){color:var(--white)}
.region-panel{display:none}
.region-panel.active{display:block}
.country-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.country-card{background:var(--dark-mid);border:1px solid rgba(255,255,255,.05);padding:16px 18px;display:flex;align-items:center;gap:14px;transition:all .3s;cursor:pointer}
.country-card:hover{border-color:var(--red);background:rgba(212,43,43,.06)}
.country-flag{font-size:1.6rem;flex-shrink:0}
.country-info{flex:1}
.country-name{font-weight:700;font-size:.85rem;margin-bottom:2px}
.country-league{font-size:.65rem;color:var(--muted)}
.country-status{display:none}
.cs-existing{color:var(--red-light);border:1px solid rgba(212,43,43,.4)}
.cs-new{color:#fbbf24;border:1px solid rgba(251,191,36,.3)}
.cs-wc{color:#7ec8e3;border:1px solid rgba(126,200,227,.3)}

/* ─── 5カテゴリ帯 ─── */
.cats-section{padding:96px 56px;background:var(--dark)}
.cats-inner{max-width:1240px;margin:0 auto}
.cats-header{text-align:center;margin-bottom:48px}
.cats-header .sec-label{justify-content:center}
.cats-header .sec-label::before{display:none}
.cats-header .sec-desc{margin:16px auto 0}
.cats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.cat-card{position:relative;aspect-ratio:3/4;background:var(--dark-mid);border:1px solid rgba(255,255,255,.06);overflow:hidden;cursor:pointer;transition:all .35s;display:flex;flex-direction:column;justify-content:flex-end;padding:24px 22px}
.cat-card::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.5) 45%,rgba(10,10,10,.2) 100%);z-index:1}
.cat-card-img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.cat-card:hover .cat-card-img{transform:scale(1.06)}
.cat-card:hover{border-color:var(--red);transform:translateY(-4px)}
.cat-card-num{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:.78rem;color:var(--red-light);letter-spacing:.15em;position:relative;z-index:2;margin-bottom:8px}
.cat-card-title{font-weight:900;font-size:1.15rem;color:var(--white);margin-bottom:6px;position:relative;z-index:2;letter-spacing:.02em}
.cat-card-sub{font-size:.66rem;color:rgba(255,255,255,.72);position:relative;z-index:2;line-height:1.6}
.cat-card.core{border-color:rgba(212,43,43,.55);background:rgba(212,43,43,.04)}
.cat-card.core .cat-card-num{color:var(--white)}

/* ─── FEATURED / LATEST STORIES ─── */
.featured-section{padding:96px 56px;background:var(--black)}
.featured-inner{max-width:1240px;margin:0 auto}
.feat-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;flex-wrap:wrap;gap:20px}
.feat-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.1);flex-wrap:wrap}
.feat-tab{font-size:.78rem;font-weight:700;letter-spacing:.08em;color:var(--muted);background:none;border:none;padding:14px 26px 16px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .25s}
.feat-tab.active{color:var(--red-light);border-bottom-color:var(--red)}
.feat-tab:hover:not(.active){color:var(--white)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
.article-card{background:var(--dark);border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:transform .3s,border-color .3s;cursor:pointer;display:block}
.article-card:hover{transform:translateY(-4px);border-color:rgba(212,43,43,.35)}
.ac-img{height:210px;position:relative;overflow:hidden;background:var(--dark-mid)}
.ac-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.article-card:hover .ac-img img{transform:scale(1.05)}
.ac-badge{position:absolute;top:12px;left:12px;font-size:.55rem;font-weight:700;letter-spacing:.12em;padding:4px 10px;background:var(--red);color:var(--white);z-index:2}
.ac-body{padding:22px}
.ac-category{font-size:.6rem;letter-spacing:.15em;color:var(--red-light);margin-bottom:8px;font-weight:700}
.ac-title{font-size:.95rem;font-weight:700;line-height:1.7;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ac-meta{font-size:.68rem;color:var(--muted);font-family:'Barlow Condensed',sans-serif;letter-spacing:.08em}
.loading-placeholder{min-height:200px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.8rem;letter-spacing:.15em;grid-column:1/-1}

/* ─── INTERVIEW ─── */
.interview-section{padding:96px 56px;background:var(--dark);position:relative}
.interview-inner{max-width:1240px;margin:0 auto}
.interview-header{margin-bottom:40px}
.interview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.interview-card{background:var(--dark-mid);overflow:hidden;transition:transform .3s,box-shadow .3s;cursor:pointer}
.interview-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(212,43,43,.15)}
.interview-card-img{width:100%;height:200px;overflow:hidden;position:relative}
.interview-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.interview-card:hover .interview-card-img img{transform:scale(1.05)}
.interview-card-body{padding:22px}
.interview-card-cat{font-size:.55rem;letter-spacing:.15em;color:var(--red-light);font-weight:700;margin-bottom:8px}
.interview-card-title{font-size:.92rem;font-weight:800;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:8px}
.interview-card-title a{color:var(--white)}
.interview-card-title a:hover{color:var(--red-light)}
.interview-card-excerpt{font-size:.75rem;color:var(--muted);line-height:1.75;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.interview-card-date{font-size:.62rem;color:var(--muted);margin-top:12px;font-family:'Barlow Condensed',sans-serif}

/* ─── SERVICES CTA ─── */
.services-section{padding:96px 56px;background:var(--black);position:relative;overflow:hidden}
.services-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:18vw;color:rgba(255,255,255,.015);white-space:nowrap;pointer-events:none}
.services-inner{max-width:1240px;margin:0 auto;position:relative;z-index:2}
.services-header{text-align:center;margin-bottom:56px}
.services-header .sec-label{justify-content:center}
.services-header .sec-label::before{display:none}
.services-header .sec-desc{margin:16px auto 0}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{background:var(--dark-mid);border:1px solid rgba(255,255,255,.06);padding:32px 26px;transition:all .35s;position:relative;overflow:hidden;cursor:pointer}
.svc-card:hover{border-color:var(--red);transform:translateY(-4px);background:rgba(212,43,43,.04)}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:0;height:3px;background:var(--red);transition:width .4s}
.svc-card:hover::before{width:100%}
.svc-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-family:'Barlow Condensed',sans-serif;font-size:1.6rem;font-weight:900;color:var(--red-light);border:1px solid rgba(212,43,43,.4);margin-bottom:20px}
.svc-title{font-weight:900;font-size:1.05rem;margin-bottom:10px;color:var(--white)}
.svc-desc{font-size:.74rem;line-height:1.75;color:var(--muted);margin-bottom:18px;min-height:64px}
.svc-cta{font-size:.7rem;font-weight:700;letter-spacing:.12em;color:var(--red-light);display:inline-flex;align-items:center;gap:6px;font-family:'Barlow Condensed',sans-serif;text-transform:uppercase}
.svc-badge{display:inline-block;font-size:.58rem;letter-spacing:.08em;color:#fbbf24;border:1px solid rgba(251,191,36,.4);padding:3px 9px;margin-bottom:12px;font-weight:700}

/* ─── ABOUT ─── */
.about-section{padding:96px 56px;background:var(--dark-mid);position:relative;overflow:hidden}
.about-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Barlow Condensed',sans-serif;font-weight:900;font-style:italic;font-size:22vw;color:rgba(255,255,255,.015);white-space:nowrap;pointer-events:none}
.about-inner{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:72px;align-items:center;position:relative;z-index:2}
.mission-quote{font-weight:900;font-size:clamp(1.3rem,2.6vw,1.9rem);line-height:1.4;color:var(--white);margin:20px 0 24px;border-left:3px solid var(--red);padding-left:22px}
.mission-quote small{display:block;font-size:.62rem;font-weight:700;color:var(--red-light);letter-spacing:.2em;margin-bottom:10px;font-family:'Barlow Condensed',sans-serif;text-transform:uppercase}
.about-text{font-size:.85rem;line-height:1.95;color:var(--muted);max-width:440px}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07);margin-top:32px}
.av-cell{background:var(--dark-mid);padding:20px 18px}
.av-lbl{font-size:.58rem;letter-spacing:.2em;color:var(--red-light);margin-bottom:6px;font-weight:700}
.av-val{font-size:.85rem;font-weight:700}
.about-img{aspect-ratio:4/5;overflow:hidden;position:relative}
.about-img img{width:100%;height:100%;object-fit:cover}
.about-img::before{content:'';position:absolute;top:14px;left:14px;width:28px;height:28px;border-top:2px solid var(--red);border-left:2px solid var(--red);z-index:2}
.about-img::after{content:'';position:absolute;bottom:14px;right:14px;width:28px;height:28px;border-bottom:2px solid var(--red);border-right:2px solid var(--red);z-index:2}

/* ─── FOOTER ─── */
footer{background:#050505;border-top:1px solid rgba(212,43,43,.15);padding:64px 56px 28px}
.ft-grid{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06)}
.ft-about p{font-size:.78rem;line-height:1.85;color:var(--muted);margin-top:14px;max-width:280px}
.ft-col h5{font-size:.65rem;font-weight:700;letter-spacing:.15em;color:var(--red-light);margin-bottom:18px;text-transform:uppercase}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.ft-col ul a{font-size:.78rem;color:var(--muted);transition:color .2s}
.ft-col ul a:hover{color:var(--white)}
.ft-btm{max-width:1240px;margin:20px auto 0;display:flex;justify-content:space-between;align-items:center}
.ft-btm p{font-size:.62rem;color:rgba(255,255,255,.2);letter-spacing:.1em}

/* ─── MEGA MENU ─── */
.mega-menu{position:fixed;inset:0;z-index:400;background:rgba(10,10,10,.97);backdrop-filter:blur(16px);display:none;flex-direction:column;justify-content:center;align-items:center;gap:28px}
.mega-menu.open{display:flex}
.mega-menu a{font-size:1.2rem;font-weight:700;color:var(--white);letter-spacing:.1em;transition:color .25s}
.mega-menu a:hover{color:var(--red-light)}
.mega-close{position:absolute;top:24px;right:32px;font-size:1.4rem;color:var(--white);cursor:pointer;background:none;border:none}

/* ─── Scroll reveal ─── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* =========================================================
   記事ページ 視認性重視のダークデザイン
   ========================================================= */

body.single,
body.page,
body.archive,
body.category,
body.search,
body.blog{background:var(--black);color:var(--off-white)}

.l-mainContent,.l-header,.l-footer,.p-articleThumb,.l-articleBody,.c-entryCard,.c-postList,.p-mainVisual,.l-sidebar,.p-articleContent{background:transparent !important}

/* メインコンテンツ幅とタイポ基盤 */
.l-container{max-width:880px;padding:0 24px}
.l-mainContent{padding-top:40px;padding-bottom:64px}

/* 記事本文 */
.p-articleContent,
.l-mainContent .post_content,
.l-mainContent .entry-content{
  font-size:1.05rem;
  line-height:2.05;
  color:#e8e8e8;
  letter-spacing:.01em;
}
.p-articleContent p,
.post_content p,
.entry-content p{
  margin:0 0 1.6em;
  color:#e8e8e8;
  line-height:2.05;
  font-size:1.05rem;
}

/* リンク */
.p-articleContent a,
.post_content a,
.entry-content a{
  color:var(--red-light);
  text-decoration:underline;
  text-decoration-color:rgba(255,68,68,.4);
  text-underline-offset:3px;
  transition:color .2s,text-decoration-color .2s;
}
.p-articleContent a:hover,
.post_content a:hover,
.entry-content a:hover{color:#ff6b6b;text-decoration-color:#ff6b6b}

/* 見出し（読みやすさ重視：サイズ・余白・装飾） */
.l-mainContent h1,
.post_content h1,.entry-content h1,
.c-postTitle__ttl{
  color:var(--white);
  font-family:'Noto Sans JP',sans-serif;
  font-weight:900;
  font-size:clamp(1.7rem,3.2vw,2.3rem);
  line-height:1.35;
  letter-spacing:.01em;
  margin:0 0 28px;
}
.post_content h2,.entry-content h2{
  color:var(--white);
  font-family:'Noto Sans JP',sans-serif;
  font-weight:900;
  font-size:1.55rem;
  line-height:1.4;
  margin:3em 0 1em;
  padding:14px 20px;
  background:linear-gradient(90deg,rgba(212,43,43,.15) 0%,rgba(212,43,43,0) 100%);
  border-left:4px solid var(--red);
  border-top:none;
  border-right:none;
  border-bottom:none;
  border-radius:0;
}
.post_content h3,.entry-content h3{
  color:var(--white);
  font-family:'Noto Sans JP',sans-serif;
  font-weight:700;
  font-size:1.25rem;
  line-height:1.5;
  margin:2.4em 0 .8em;
  padding:0 0 8px;
  border-bottom:2px solid rgba(212,43,43,.35);
  border-top:none;
  border-left:none;
  border-right:none;
}
.post_content h4,.entry-content h4{
  color:#fff;
  font-weight:700;
  font-size:1.08rem;
  margin:1.8em 0 .6em;
  padding-left:14px;
  border-left:3px solid rgba(255,68,68,.5);
}

/* 強調・リスト */
.post_content strong,.entry-content strong{color:#fff;font-weight:700;background:linear-gradient(transparent 60%,rgba(212,43,43,.35) 60%)}
.post_content ul,.entry-content ul,
.post_content ol,.entry-content ol{margin:0 0 1.8em 1.4em;line-height:2;color:#e8e8e8}
.post_content ul li,.entry-content ul li{margin-bottom:.4em;padding-left:.2em}
.post_content ul li::marker{color:var(--red)}

/* 引用 */
.post_content blockquote,.entry-content blockquote{
  background:var(--dark-mid);
  border:none;
  border-left:4px solid var(--red);
  padding:20px 24px;
  margin:2em 0;
  color:rgba(255,255,255,.85);
  font-style:normal;
  line-height:1.95;
}
.post_content blockquote p,.entry-content blockquote p{margin-bottom:.8em}

/* テーブル */
.post_content table,.entry-content table{
  width:100%;
  margin:1.8em 0;
  border-collapse:collapse;
  font-size:.95rem;
}
.post_content table th,.entry-content table th{
  background:var(--dark-mid);
  color:#fff;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.12);
  font-weight:700;
  text-align:left;
}
.post_content table td,.entry-content table td{
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(24,24,24,.5);
  color:#e8e8e8;
}

/* コード */
.post_content code,.entry-content code{
  background:rgba(212,43,43,.12);
  color:#ff6b6b;
  padding:2px 8px;
  border-radius:3px;
  font-size:.9em;
  font-family:'SFMono-Regular',Menlo,Consolas,monospace;
}
.post_content pre,.entry-content pre{
  background:#0d0d0d;
  border:1px solid rgba(255,255,255,.08);
  padding:20px;
  overflow-x:auto;
  line-height:1.7;
  margin:2em 0;
}

/* 画像 */
.post_content img,.entry-content img{
  max-width:100%;
  height:auto;
  margin:1.5em 0;
  border-radius:3px;
}
.post_content figure,.entry-content figure{margin:2em 0}
.post_content figcaption,.entry-content figcaption{font-size:.82rem;color:var(--muted);margin-top:8px;text-align:center}

/* 目次 */
.p-toc{
  background:var(--dark-mid);
  border:1px solid rgba(255,255,255,.08);
  border-left:3px solid var(--red);
  color:var(--off-white);
  padding:20px 24px;
  margin:2em 0;
  border-radius:0;
}
.p-toc__title{color:var(--red-light) !important;background:none !important;font-weight:700;letter-spacing:.06em;margin-bottom:14px}
.p-toc ol,.p-toc ul{color:#e8e8e8;line-height:1.9}
.p-toc a{color:#e8e8e8;text-decoration:none}
.p-toc a:hover{color:var(--red-light)}

/* 投稿タイトル・メタ */
.c-postTitle,.c-pageTitle{padding:40px 0 20px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:32px}
.c-postTitle__ttl,.c-pageTitle__ttl{color:var(--white) !important}
.c-postTimes,.p-postInfo,.c-postMeta{color:var(--muted) !important;font-family:'Barlow Condensed',sans-serif;letter-spacing:.08em;font-size:.78rem}

/* カテゴリラベル */
.c-postMetas .cat-name,.c-postTaxes a,.cat-link{
  background:var(--red) !important;
  color:#fff !important;
  padding:4px 10px !important;
  font-size:.68rem !important;
  letter-spacing:.1em;
  font-weight:700;
  text-decoration:none !important;
}

/* 記事カード（一覧ページ） */
.c-entryCard,.p-postList__item{
  background:var(--dark-mid) !important;
  border:1px solid rgba(255,255,255,.06) !important;
  transition:transform .3s,border-color .3s;
}
.c-entryCard:hover,.p-postList__item:hover{transform:translateY(-3px);border-color:rgba(212,43,43,.35) !important}
.c-entryCard__ttl,.p-postList__ttl{color:var(--white) !important;font-weight:700}
.c-entryCard__meta,.p-postList__meta{color:var(--muted) !important}

/* 関連記事・前後記事 */
.p-relatedPosts,.p-prevNextNav{background:transparent;margin-top:3em}
.p-relatedPosts__title,.p-prevNextNav__title{color:var(--white);border-left:3px solid var(--red);padding-left:14px}

/* サイドバー */
.l-sidebar .p-widget{margin-bottom:2em}
.l-sidebar .p-widget__title{color:var(--red-light);border-left:3px solid var(--red);padding-left:12px;font-size:.88rem;letter-spacing:.1em;margin-bottom:14px}
.l-sidebar a{color:#e8e8e8}
.l-sidebar a:hover{color:var(--red-light)}

/* SWELLの不要装飾を抑制 */
.c-ads,.p-ads,.p-articleFoot__date,.c-postTimeline{display:none}
.p-sharesBtns{margin:2em 0;padding:1em 0;border-top:1px solid rgba(255,255,255,.08);border-bottom:1px solid rgba(255,255,255,.08)}

/* モバイル記事ページ */
@media(max-width:640px){
  .l-container{padding:0 16px}
  .l-mainContent{padding-top:24px;padding-bottom:40px}
  .p-articleContent,.post_content,.entry-content{font-size:1rem;line-height:1.95}
  .p-articleContent p,.post_content p,.entry-content p{font-size:1rem;line-height:1.95;margin-bottom:1.4em}
  .post_content h2,.entry-content h2{font-size:1.25rem;padding:10px 14px;margin:2.2em 0 .8em}
  .post_content h3,.entry-content h3{font-size:1.1rem;margin:2em 0 .6em}
  .c-postTitle__ttl{font-size:1.4rem !important}
}

/* =========================================================
   RESPONSIVE（モバイル最適化：2段階）
   ========================================================= */

/* ─── タブレット（〜1024px）─── */
@media(max-width:1024px){
  .gh{padding:0 20px}
  .gh-nav,.gh-cta{display:none}
  .gh-hamburger{display:flex}
  .escape-section,.cats-section,.featured-section,.interview-section,.services-section,.about-section{padding:80px 32px}
  .hero-copy{left:32px;right:32px;bottom:88px}
  .hero-nav{right:32px}
  .cats-grid{grid-template-columns:repeat(3,1fr)}
  .feat-grid,.interview-grid,.services-grid{grid-template-columns:repeat(2,1fr)}
  .escape-header{grid-template-columns:1fr;gap:20px}
  .escape-cta-wrap{text-align:left}
  .about-inner{gap:48px}
  .ft-grid{grid-template-columns:2fr 1fr 1fr;gap:32px}
  footer{padding:56px 32px 28px}
}

/* ─── モバイル（〜640px）─── */
@media(max-width:640px){
  :root{--gh-h:56px}
  .gh{padding:0 16px}
  .gh-logo-img{height:28px}
  .gh-logo-txt{font-size:.95rem}
  .gh-nav,.gh-cta{display:none}
  .gh-hamburger{display:flex}

  /* HERO */
  .hero{min-height:560px}
  .hero-copy{left:18px;right:18px;bottom:72px}
  .hero-eyebrow{font-size:.78rem;padding:6px 14px;margin-bottom:18px}
  .hero-title{font-size:2rem;line-height:1.22;margin-bottom:14px}
  .hero-sub{font-size:.88rem;line-height:1.7;margin-bottom:22px}
  .btn{padding:12px 22px;font-size:.72rem}
  .hero-nav{right:18px;bottom:22px}
  .hero-nav-btn{width:38px;height:38px;font-size:.85rem}

  /* セクション共通 */
  .escape-section,.cats-section,.featured-section,.interview-section,.services-section,.about-section{padding:56px 18px}
  .sec-title{font-size:1.6rem;line-height:1.3}
  .sec-desc{font-size:.82rem;line-height:1.85}

  /* ESCAPE */
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .stat-cell{padding:20px 10px}
  .stat-num{font-size:2rem}
  .country-grid{grid-template-columns:1fr}
  .region-tab{padding:10px 14px;font-size:.68rem}

  /* 5カテゴリ：2列 */
  .cats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cat-card{aspect-ratio:4/5;padding:18px 16px}
  .cat-card-title{font-size:1rem}
  .cat-card-sub{font-size:.62rem}

  /* FEATURED/INTERVIEW/SERVICES：1列 */
  .feat-grid,.interview-grid,.services-grid{grid-template-columns:1fr;gap:16px}
  .feat-tab{padding:10px 14px;font-size:.7rem}
  .ac-img,.interview-card-img{height:180px}
  .ac-body,.interview-card-body{padding:18px}
  .svc-card{padding:24px 20px}
  .svc-desc{min-height:auto}

  /* ABOUT */
  .about-inner{grid-template-columns:1fr;gap:36px}
  .mission-quote{font-size:1.15rem;padding-left:16px;margin:14px 0 18px;line-height:1.5}
  .about-values{grid-template-columns:1fr 1fr}
  .av-cell{padding:16px 14px}

  /* FOOTER */
  footer{padding:48px 18px 24px}
  .ft-grid{grid-template-columns:1fr 1fr;gap:24px}
  .ft-about{grid-column:1/-1}
  .ft-btm{flex-direction:column;gap:10px;text-align:center;align-items:center}

  /* 記事ページもモバイル調整 */
  .l-mainContent h2{font-size:1.3rem}
  .l-mainContent h3{font-size:1.1rem}
  .l-mainContent p{font-size:.95rem}
}

/* ─── 小型スマホ（〜380px）─── */
@media(max-width:380px){
  .hero-title{font-size:1.7rem}
  .cats-grid{grid-template-columns:1fr}
  .stats-strip{grid-template-columns:1fr 1fr}
}
