/*
Theme Name: OKA-SHOW
Theme URI: https://oka-show.site/
Author: Shogo Okagawa
Description: 映像・ドローン・Web/システム開発のポートフォリオ用オリジナルテーマ。Blue Flame配色 / 3Dエネルギーコア / スクロール演出。
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: oka-show
*/

/* ════════════════════════════════════════════════════════════
   OKA-SHOW  共通スタイル
   配色 = Blue Flame（青）固定
   ※ WordPress化の際は、このファイルがテーマの style.css のベースになります
   ════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Anton&family=Noto+Sans+JP:wght@100;300;400;500&family=Space+Mono:wght@400;700&display=swap');

:root{
  --bg:#06080f; --bg2:#0b0f1c; --fg:#eaf0fb;
  --mid:#586079; --brd:#151b2b;
  --acc:#3d7bff; --acc2:#27e0d0;
  --glow:rgba(61,123,255,.45);
  --logo-acc:#d8543d; /* ロゴのレンガ色アクセント */
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:'Noto Sans JP',sans-serif;font-weight:300;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.acc{color:var(--acc)}
.grad{background:linear-gradient(120deg,var(--acc),var(--acc2));-webkit-background-clip:text;background-clip:text;color:transparent}

.bg-glow{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background:radial-gradient(60vw 60vw at 80% -10%,var(--glow),transparent 60%),radial-gradient(50vw 50vw at -10% 110%,var(--glow),transparent 55%)}

/* ════ ローダー ════ */
#loader{position:fixed;inset:0;z-index:10000;background:var(--bg);display:flex;align-items:flex-end;justify-content:space-between;padding:48px 56px}
#loader .ld-logo{width:clamp(90px,16vw,170px);color:var(--fg)}
#loader .ld-num{font-family:'Space Mono',monospace;font-size:clamp(40px,9vw,120px);line-height:.9}
.ld-bar{position:absolute;left:0;bottom:0;height:2px;width:0;background:linear-gradient(90deg,var(--acc),var(--acc2))}

/* ════ カーソル ════ */
#cur,#ring{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;opacity:0;transition:opacity .3s}
#cur{width:7px;height:7px;background:var(--acc);transform:translate(-50%,-50%)}
#ring{width:38px;height:38px;border:1px solid rgba(255,255,255,.4);transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s,opacity .3s}
#ring.big{width:70px;height:70px;border-color:var(--acc)}
.cursor-on #cur,.cursor-on #ring{opacity:1}
.cursor-on,.cursor-on a,.cursor-on button{cursor:none}

/* ════ 進捗 ════ */
#sp{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--acc),var(--acc2));z-index:9000;width:0}

/* ════ ナビ ════ */
nav{position:fixed;top:0;left:0;right:0;z-index:800;display:flex;align-items:center;justify-content:space-between;padding:18px 56px;mix-blend-mode:difference}
.n-logo{display:flex;align-items:center;color:var(--fg)}
.n-logo svg{height:34px;width:auto}
.n-right{display:flex;align-items:center;gap:26px}
.n-pct{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;opacity:.5}
.menu-btn{display:flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:10px;letter-spacing:3px;background:none;border:none;color:var(--fg)}
.menu-btn .bars{display:flex;flex-direction:column;gap:4px;width:22px}
.menu-btn .bars i{height:1.5px;background:var(--fg);display:block;transition:.35s}

/* ════ フルスクリーンメニュー ════ */
#menu{position:fixed;inset:0;z-index:790;background:var(--bg2);clip-path:circle(0% at 100% 0);transition:clip-path .7s cubic-bezier(.76,0,.24,1);display:flex;flex-direction:column;justify-content:center;padding:0 8vw}
#menu.open{clip-path:circle(150% at 100% 0)}
.m-link{font-family:'Anton',sans-serif;font-size:clamp(40px,9vw,96px);line-height:1.05;letter-spacing:-1px;color:var(--fg);opacity:.85;transition:.3s;width:fit-content}
.m-link:hover{color:var(--acc);padding-left:24px}
.m-link span{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:2px;color:var(--mid);vertical-align:super;margin-left:10px}
.m-foot{margin-top:48px;display:flex;gap:26px;flex-wrap:wrap}
.m-foot a{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--mid)}
.m-foot a:hover{color:var(--acc)}

/* ════ フローティング操作ボタン ════ */
.to-top,.to-home{position:fixed;bottom:24px;z-index:850;display:inline-flex;align-items:center;justify-content:center;
  font-family:'Space Mono',monospace;letter-spacing:2px;border:1px solid var(--brd);background:rgba(11,15,28,.7);
  backdrop-filter:blur(10px);color:var(--fg);transition:.35s;cursor:pointer}
.to-top:hover,.to-home:hover{border-color:var(--acc);color:var(--acc);box-shadow:0 0 24px var(--glow)}
/* 上部へ戻る（右下・スクロールで出現） */
.to-top{right:24px;width:50px;height:50px;border-radius:50%;font-size:18px;opacity:0;transform:translateY(20px);pointer-events:none}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
/* TOPへ戻る（左下・下層ページのみ） */
.to-home{left:24px;height:46px;padding:0 20px;border-radius:100px;font-size:10px;gap:8px}

/* ════ ヒーロー（TOP） ════ */
.hero{height:100vh;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.hero-fallback{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,var(--bg) 0%,var(--bg2) 50%,var(--bg) 100%);background-size:200% 200%;animation:bgmove 18s ease infinite}
/* エネルギーコア（Three.js）キャンバス */
#energy-core{position:absolute;inset:0;z-index:1;pointer-events:none}
#energy-core canvas{width:100%!important;height:100%!important;display:block}
.h-ey #roleRoll{color:var(--acc);transition:opacity .4s}
@keyframes bgmove{0%{background-position:0 0}50%{background-position:100% 100%}100%{background-position:0 0}}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5}
.hero-ov{position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(6,8,15,.15),rgba(6,8,15,.35) 55%,var(--bg) 100%)}
.hero-cnt{position:relative;z-index:10;text-align:center;padding:0 24px}
.h-ey{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:6px;color:var(--acc);margin-bottom:22px}
.h-ttl{font-family:'Anton',sans-serif;font-size:clamp(64px,13vw,128px);line-height:.86;letter-spacing:-3px}
.h-ttl .out{-webkit-text-stroke:1.5px var(--fg);color:transparent}
.h-ovf{overflow:hidden}
.h-tags{margin-top:26px;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.h-tag{font-family:'Space Mono',monospace;font-size:8px;letter-spacing:3px;padding:5px 14px;border:1px solid rgba(255,255,255,.16);color:var(--mid);border-radius:100px}
.h-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px}
.h-scroll span{font-family:'Space Mono',monospace;font-size:8px;letter-spacing:4px;color:var(--mid)}
.h-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--mid),var(--acc));animation:la 2s ease-in-out infinite}
@keyframes la{0%{transform:scaleY(0);transform-origin:top;opacity:0}50%{transform:scaleY(1);transform-origin:top;opacity:1}100%{transform:scaleY(0);transform-origin:bottom;opacity:0}}

/* ════ 下層ページのページヘッダー ════ */
.page-hero{min-height:54vh;display:flex;flex-direction:column;justify-content:flex-end;padding:140px 56px 60px;position:relative;border-bottom:1px solid var(--brd)}
.page-hero .ph-num{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--acc)}
.page-hero h1{font-family:'Anton',sans-serif;font-size:clamp(56px,12vw,150px);line-height:.9;letter-spacing:-3px;margin-top:14px}
.page-hero .ph-lead{font-size:14px;line-height:1.9;color:var(--mid);max-width:54ch;margin-top:20px}
.crumb{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--mid);margin-bottom:8px}
.crumb a:hover{color:var(--acc)}

/* ════ マーキー ════ */
.mq{overflow:hidden;border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);background:var(--bg2)}
.mq-tr{display:flex;white-space:nowrap;width:max-content;animation:mqr 26s linear infinite}
.mi{font-family:'Anton',sans-serif;font-size:clamp(40px,6vw,68px);letter-spacing:-1px;padding:10px 30px;color:transparent;-webkit-text-stroke:1px var(--brd);transition:.3s}
.mi.lit,.mi:hover{color:var(--acc);-webkit-text-stroke:none}
.md{font-family:'Anton',sans-serif;font-size:clamp(40px,6vw,68px);color:var(--acc);padding:10px 2px}
@keyframes mqr{to{transform:translateX(-50%)}}

/* ════ セクション共通 ════ */
section{padding:120px 56px;position:relative}
.s-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px;flex-wrap:wrap;gap:20px}
.s-num{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--acc)}
.s-title{font-family:'Anton',sans-serif;font-size:clamp(40px,7vw,88px);line-height:.9;letter-spacing:-2px}
.s-more{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--mid);border-bottom:1px solid var(--brd);padding-bottom:4px;transition:.3s}
.s-more:hover{color:var(--acc);border-color:var(--acc)}

.rv{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}
.rv.in{opacity:1;transform:none}

/* ════ イントロ大コピー ════ */
.intro{padding:140px 56px;max-width:1100px}
.intro p{font-weight:300;font-size:clamp(22px,3.4vw,44px);line-height:1.5;letter-spacing:.5px}
.intro .ln{display:block;overflow:hidden}
.intro .ln b{display:inline-block;font-weight:300}

/* ════ 3Dリールスクロール ════ */
.reel-outer{position:relative;height:880vh}  /* スクロール距離を長く＝rwゆっくり＋末尾に余韻 */
.reel-stage{position:sticky;top:0;height:100vh;overflow:hidden;background:#000;perspective:1000px;perspective-origin:50% 50%;display:flex;align-items:center;justify-content:center}
.reel-vbg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;filter:blur(9px) saturate(1.1);transform:scale(1.08);z-index:0}
.reel-grad{position:absolute;inset:0;background:linear-gradient(135deg,var(--bg),var(--bg2),#000);background-size:200% 200%;animation:bgmove 18s ease infinite;opacity:0;z-index:0}
/* シネマ調ヴィネット＋上下の帯で“魅せる”背景に */
.reel-blur{position:absolute;inset:0;opacity:0;z-index:1;
  background:radial-gradient(120% 90% at 50% 50%,rgba(6,8,15,.15),rgba(6,8,15,.78) 100%),
  linear-gradient(to bottom,rgba(6,8,15,.55),transparent 22%,transparent 78%,rgba(6,8,15,.85))}
.reel-copy{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:4;pointer-events:none}
.rcl{overflow:hidden;line-height:1.08;margin:2px 0}
.rcl-inner{display:block;font-family:'Anton',sans-serif;font-size:clamp(30px,6vw,68px);letter-spacing:-1px}
.rcl-inner.it{font-family:'Noto Sans JP',sans-serif;font-style:italic;font-weight:100;font-size:clamp(20px,4vw,46px);letter-spacing:3px;color:var(--mid)}
.rw{position:absolute;width:clamp(260px,32vw,440px);overflow:hidden;border-radius:4px;will-change:transform,opacity}
.rw img{width:100%;aspect-ratio:16/9;object-fit:cover}
.rw-label{position:absolute;left:0;right:0;bottom:0;padding:40px 14px 12px;background:linear-gradient(to top,rgba(0,0,0,.9),transparent)}
.rw-cat{font-family:'Space Mono',monospace;font-size:7px;letter-spacing:3px;padding:2px 9px;border:1px solid rgba(255,255,255,.25);border-radius:100px;background:rgba(0,0,0,.5)}
.rw-title{font-family:'Anton',sans-serif;font-size:15px;letter-spacing:1px;margin-top:6px}
.reel-play{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5;opacity:0;pointer-events:none;color:var(--fg)}
.reel-play.active{pointer-events:all}
.play-btn{position:relative;width:92px;height:92px;border:1px solid rgba(255,255,255,.45);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.35s;backdrop-filter:blur(2px)}
/* 脈動リング */
.play-btn::before{content:"";position:absolute;inset:-1px;border-radius:50%;border:1px solid var(--acc);opacity:.6;animation:playpulse 2.4s ease-out infinite}
@keyframes playpulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.6);opacity:0}}
.reel-play:hover .play-btn{border-color:var(--acc);transform:scale(1.08);box-shadow:0 0 40px var(--glow)}
.play-icon{width:0;height:0;border-left:18px solid var(--fg);border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px}
.play-text{font-family:'Anton',sans-serif;font-size:22px;letter-spacing:4px;margin-top:20px}
.play-handle{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--mid);margin-top:8px;transition:.3s}
.reel-play:hover .play-handle{color:var(--acc)}

/* ════ WORKSグリッド（TOPプレビュー = 非対称） ════ */
.wg{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.wc{position:relative;overflow:hidden;border-radius:4px;cursor:pointer;display:block}
.wc img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.wc:hover img{transform:scale(1.06)}
.wc::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent 55%);opacity:.6;transition:.4s}
.wc:hover::after{opacity:.85}
.wc-meta{position:absolute;left:18px;bottom:16px;z-index:2}
.wc-cat{font-family:'Space Mono',monospace;font-size:8px;letter-spacing:3px;color:var(--acc)}
.wc-ttl{font-family:'Anton',sans-serif;font-size:clamp(18px,2vw,26px);margin-top:4px}
.w-lg{grid-column:span 7;aspect-ratio:16/10}
.w-sm{grid-column:span 5;aspect-ratio:16/11}
.w-md{grid-column:span 4;aspect-ratio:4/5}
.w-wide{grid-column:span 8;aspect-ratio:16/8}

/* ════ WORKS一覧ページ（均一グリッド＋フィルタ） ════ */
.filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:48px}
.filter button{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--mid);background:none;border:1px solid var(--brd);border-radius:100px;padding:10px 20px;cursor:pointer;transition:.3s}
.filter button:hover{color:var(--fg);border-color:var(--mid)}
.filter button.on{color:var(--bg);background:var(--acc);border-color:var(--acc)}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.work-card{position:relative;overflow:hidden;border-radius:4px;display:block;aspect-ratio:4/3;transition:opacity .4s,transform .4s}
.work-card.hide{display:none}
.work-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.work-card:hover img{transform:scale(1.07)}
.work-card::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75),transparent 60%);transition:.4s}
.work-card .wc-meta{left:20px;bottom:18px}
.work-card .wc-ttl{font-size:20px}

/* ════ WORKS詳細ページ ════ */
.detail-hero{position:relative;height:80vh;overflow:hidden;border-bottom:1px solid var(--brd)}
.detail-hero img,.detail-hero video{width:100%;height:100%;object-fit:cover}
.detail-hero .dh-ov{position:absolute;inset:0;background:linear-gradient(to top,var(--bg),transparent 55%)}
.detail-hero .dh-cap{position:absolute;left:56px;bottom:48px;z-index:2}
.detail-hero .dh-cat{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--acc)}
.detail-hero h1{font-family:'Anton',sans-serif;font-size:clamp(40px,8vw,104px);line-height:.92;letter-spacing:-2px;margin-top:12px}
.detail-body{display:grid;grid-template-columns:1.6fr 1fr;gap:64px;padding:90px 56px;max-width:1300px;margin:0 auto}
.detail-body .lead{font-family:'Anton',sans-serif;font-size:clamp(22px,2.6vw,34px);line-height:1.3;letter-spacing:-1px;margin-bottom:24px}
.detail-body p{font-size:14px;line-height:2;color:var(--mid);margin-bottom:18px}
.detail-meta{border-left:1px solid var(--brd);padding-left:32px;height:fit-content}
.detail-meta dt{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--mid);margin-top:22px}
.detail-meta dt:first-child{margin-top:0}
.detail-meta dd{font-size:14px;margin-top:6px}
.detail-meta .embed{margin-top:30px;aspect-ratio:16/9;background:var(--bg2);border:1px solid var(--brd);border-radius:4px;display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-size:10px;color:var(--mid);letter-spacing:2px}
.detail-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:0 56px 90px;max-width:1300px;margin:0 auto}
.detail-gallery img{width:100%;border-radius:4px;aspect-ratio:16/10;object-fit:cover}
.detail-gallery .full{grid-column:1/-1;aspect-ratio:16/7}
.detail-nav{display:flex;justify-content:space-between;border-top:1px solid var(--brd);padding:40px 56px}
.detail-nav a{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--mid);transition:.3s}
.detail-nav a:hover{color:var(--acc)}
.detail-nav a.next{margin-left:auto}

/* ════ ABOUT（TOPの簡易自己紹介） ════ */
.ab-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:center}
.ab-photo{position:relative;overflow:hidden;border-radius:4px}
.ab-photo img{width:100%;aspect-ratio:4/5;object-fit:cover}
.ab-photo-label{position:absolute;left:18px;bottom:18px;font-family:'Anton',sans-serif;font-size:20px;letter-spacing:1px}
.ab-photo-label em{display:block;font-family:'Space Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--acc);font-style:normal;margin-top:4px}
.ab-lead{font-family:'Anton',sans-serif;font-size:clamp(26px,3.4vw,44px);line-height:1.15;letter-spacing:-1px}
.ab-lead .hl{color:var(--acc)}
.ab-body{font-size:14px;line-height:2;color:var(--mid);margin:24px 0 28px;max-width:46ch}
.ab-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.ab-tag{font-family:'Space Mono',monospace;font-size:8px;letter-spacing:2px;padding:6px 12px;border:1px solid var(--brd);border-radius:100px;color:var(--mid)}
.sk{margin-bottom:14px}
.sk-nm{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;display:flex;justify-content:space-between}
.sk-nm span:last-child{color:var(--acc)}
.sk-bar{height:2px;background:var(--brd);margin-top:8px;overflow:hidden}
.sk-fill{height:100%;width:0;background:linear-gradient(90deg,var(--acc),var(--acc2));transition:width 1.2s cubic-bezier(.22,1,.36,1)}

/* ════ STATS ════ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:80px 56px;border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.st-n{font-family:'Anton',sans-serif;font-size:clamp(40px,6vw,76px);line-height:1;letter-spacing:-2px}
.st-n .su{color:var(--acc);font-size:.5em}
.st-l{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:3px;color:var(--mid);margin-top:10px}

/* ════ SERVICES ════ */
.sv{border-top:1px solid var(--brd);padding:30px 0;display:flex;gap:28px;cursor:pointer;align-items:flex-start;transition:.3s}
.sv:last-child{border-bottom:1px solid var(--brd)}
.sv:hover{padding-left:14px}
.sv-n{font-family:'Space Mono',monospace;font-size:11px;color:var(--acc);padding-top:8px}
.sv-bd{flex:1}
.sv-nm{font-family:'Anton',sans-serif;font-size:clamp(24px,3.2vw,42px);letter-spacing:-1px;display:flex;justify-content:space-between;align-items:center}
.sv-nm .pl{font-size:.5em;color:var(--mid);transition:.3s}
.sv.open .sv-nm .pl{transform:rotate(45deg);color:var(--acc)}
.sv-desc{max-height:0;overflow:hidden;transition:max-height .5s ease,margin .5s ease;font-size:14px;line-height:1.9;color:var(--mid);max-width:60ch}
.sv.open .sv-desc{max-height:240px;margin-top:16px}

/* ════ CTA ════ */
.cta{text-align:center;padding:140px 24px;position:relative;overflow:hidden}
.cta-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Anton',sans-serif;font-size:clamp(80px,20vw,300px);color:var(--brd);white-space:nowrap;z-index:0;opacity:.5}
.cta-lb{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--acc);position:relative;z-index:1}
.cta-ttl{font-family:'Anton',sans-serif;font-size:clamp(48px,10vw,128px);line-height:.9;letter-spacing:-3px;margin:18px 0 40px;position:relative;z-index:1}
.cta-ttl .out{-webkit-text-stroke:1.5px var(--fg);color:transparent}
.btn{position:relative;z-index:1;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:3px;color:var(--bg);background:var(--acc);border:none;padding:20px 44px;border-radius:100px;display:inline-flex;gap:8px;cursor:pointer;transition:.3s}
.btn:hover{gap:18px;box-shadow:0 0 40px var(--glow)}
.btn-ghost{color:var(--fg);background:none;border:1px solid var(--brd)}
.btn-ghost:hover{border-color:var(--acc);box-shadow:none}

/* ════ お問い合わせフォーム ════ */
.contact-wrap{display:grid;grid-template-columns:1fr 1.3fr;gap:72px;padding:90px 56px;max-width:1300px;margin:0 auto}
.contact-info h2{font-family:'Anton',sans-serif;font-size:clamp(28px,3.4vw,46px);line-height:1.1;letter-spacing:-1px;margin-bottom:20px}
.contact-info p{font-size:14px;line-height:2;color:var(--mid);margin-bottom:30px;max-width:38ch}
.ci-row{border-top:1px solid var(--brd);padding:20px 0}
.ci-row:last-child{border-bottom:1px solid var(--brd)}
.ci-row .k{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--mid)}
.ci-row .v{font-size:15px;margin-top:6px}
.ci-row .v a:hover{color:var(--acc)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--mid)}
.field label .req{color:var(--acc)}
.field input,.field textarea,.field select{background:var(--bg2);border:1px solid var(--brd);border-radius:4px;color:var(--fg);font-family:'Noto Sans JP',sans-serif;font-size:14px;padding:14px 16px;transition:.3s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--acc);box-shadow:0 0 0 3px var(--glow)}
.field textarea{min-height:160px;resize:vertical}
.form-foot{grid-column:1/-1;display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:8px;flex-wrap:wrap}
.form-note{font-size:11px;color:var(--mid);line-height:1.7}
.privacy{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--mid);grid-column:1/-1}
.privacy a{color:var(--acc);text-decoration:underline}

/* ════ CTA到達で色反転ギミック ════ */
body{transition:background-color .6s ease,color .6s ease}
.cta,.cta-bg,.cta-lb,.cta-ttl,.btn,.f-logo,.f-copy,.f-sns a,footer,.crumb,.to-top,.to-home{
  transition:color .55s ease,background-color .55s ease,border-color .55s ease,box-shadow .3s ease}
body.invert{
  --bg:#eef2fb; --bg2:#e1e8f6; --fg:#070b16;
  --mid:#6c7488; --brd:#c4cde0;
  --acc:#1f4fd0; --acc2:#1f9fb0; --glow:rgba(31,79,208,.28);
}

/* ════ フッター ════ */
footer{padding:48px 56px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;border-top:1px solid var(--brd)}
.f-logo{color:var(--fg)}
.f-logo svg{height:30px;width:auto}
.f-copy,.f-sns a{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:2px;color:var(--mid)}
.f-sns{display:flex;gap:20px}
.f-sns a:hover{color:var(--acc)}

/* ════ レスポンシブ ════ */
@media(max-width:980px){
  .detail-body,.contact-wrap{grid-template-columns:1fr;gap:40px}
  .detail-meta{border-left:none;border-top:1px solid var(--brd);padding-left:0;padding-top:28px}
  .work-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  nav,section,.intro,.stats,footer,.page-hero,.detail-body,.detail-gallery,.detail-nav,.contact-wrap{padding-left:24px;padding-right:24px}
  .detail-hero .dh-cap{left:24px}
  .ab-grid{grid-template-columns:1fr;gap:32px}
  .stats{grid-template-columns:repeat(2,1fr);gap:32px 20px}
  .wg{grid-template-columns:repeat(6,1fr)}
  .w-lg,.w-sm,.w-md,.w-wide{grid-column:span 6;aspect-ratio:16/10}
  .form-grid{grid-template-columns:1fr}
  .n-pct{display:none}
  .reel-outer{height:520vh}
}
@media(max-width:560px){
  .work-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important}
  .rv{opacity:1;transform:none}
}

/* ════ WordPress追加（動画埋め込み / Contact Form 7 / WP標準） ════ */
.embed-frame{position:relative;aspect-ratio:16/9;margin-top:30px;border:1px solid var(--brd);border-radius:4px;overflow:hidden}
.embed-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* CF7 をデザインに馴染ませる */
.wpcf7-form .form-foot .btn{cursor:pointer}
.wpcf7-form input[type=submit]{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:3px;color:var(--bg);background:var(--acc);border:none;padding:18px 40px;border-radius:100px;cursor:pointer;transition:.3s}
.wpcf7-form input[type=submit]:hover{box-shadow:0 0 40px var(--glow)}
.wpcf7-response-output{margin:18px 0 0!important;border-radius:4px;font-size:13px;color:var(--fg)}
.wpcf7-not-valid-tip{color:#ff7a7a;font-size:11px;margin-top:4px}
.wpcf7 .wpcf7-spinner{margin:0 0 0 10px}
/* WPページネーション */
.pagination,.wp-pagenavi,.nav-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:48px;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:2px}
.nav-links .page-numbers{padding:10px 16px;border:1px solid var(--brd);border-radius:100px;color:var(--mid);transition:.3s}
.nav-links .page-numbers.current,.nav-links a.page-numbers:hover{color:var(--bg);background:var(--acc);border-color:var(--acc)}
/* 投稿本文（the_content）の基本タイポ */
.detail-body .rv > p{font-size:14px;line-height:2;color:var(--mid);margin-bottom:18px}
.detail-body .rv h2,.detail-body .rv h3{font-family:'Anton',sans-serif;letter-spacing:-.5px;margin:24px 0 12px}

/* ════════ 本番修正パッチ ════════ */
/* リールのリンクが効かない → 背面オーバーレイのクリックを透過し、サムネを前面に */
.reel-vbg,.reel-grad,.reel-blur{pointer-events:none}
.rw{pointer-events:auto;z-index:3}
.reel-copy{z-index:4}      /* コピーは pointer-events:none のままクリック透過 */
.reel-play{z-index:6}

/* ページネーション：中央寄せ・はっきり見える色に */
.navigation.pagination,.pagination .nav-links,.nav-links{
  display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;
  margin:64px auto 8px;width:100%}
.nav-links .page-numbers{
  min-width:42px;height:42px;padding:0 14px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--brd);border-radius:100px;color:var(--fg);background:rgba(255,255,255,.03);
  font-family:'Space Mono',monospace;font-size:12px;letter-spacing:1px;transition:.3s}
.nav-links .page-numbers.current,.nav-links a.page-numbers:hover{
  color:var(--bg);background:var(--acc);border-color:var(--acc)}
.nav-links .page-numbers.dots{border:none;background:none}

/* Contact Form 7：CF7が input を <span> で包むため全幅にならずズレる → 全幅化 */
.field .wpcf7-form-control-wrap{display:block;width:100%}
.field .wpcf7-form-control{width:100%}
.form-grid .wpcf7-form-control-wrap{margin:0}
/* WORKS下の「VIEW ALL WORKS」ボタン */
.works-more{text-align:center;margin-top:52px}
