/* =========================================================
   JAPAN ACTION FILM CAMP — Landing Page  v0.2.0
   tokens shared with form: ink #1a1a1a / red #e63946 / green #1a9f5c
   ========================================================= */
:root{
  --ink:#1a1a1a;
  --bg:#ffffff;
  --bg2:#fafafa;
  --dark:#121212;
  --dark2:#1c1c1c;
  --line:#e6e6e6;
  --red:#e63946;
  --red-d:#c32a36;
  --green:#1a9f5c;
  --green-d:#178a51;
  --muted:#6a6a6a;
  --maxw:1080px;
}
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.8;font-size:15px;
}
img{max-width:100%;display:block;}
a{color:var(--green-d);}
.bebas{font-family:"Bebas Neue",sans-serif;}

/* ---------- ナビ ---------- */
.nav{
  position:sticky;top:0;z-index:50;background:rgba(18,18,18,.96);
  backdrop-filter:saturate(140%) blur(4px);border-bottom:3px solid var(--red);
}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:12px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.nav__brand{display:flex;align-items:center;gap:11px;color:#fff;text-decoration:none;}
.nav__bar{width:5px;height:34px;background:var(--red);display:block;}
.nav__logo{height:30px;width:auto;display:block;}
.nav__title{font-family:"Bebas Neue",sans-serif;font-size:21px;line-height:.95;letter-spacing:.04em;}
.nav__links{display:flex;align-items:center;gap:26px;}
.nav__links a{color:#d8d8d8;text-decoration:none;font-size:13px;font-weight:500;transition:color .15s;}
.nav__links a:hover{color:#fff;}
.nav__cta{
  background:var(--red);color:#fff!important;padding:9px 20px;border-radius:6px;
  font-weight:700;font-size:13px;letter-spacing:.02em;
}
.nav__cta:hover{background:var(--red-d);}
@media(max-width:820px){ .nav__links a:not(.nav__cta){display:none;} }

/* ---------- ヒーロー ---------- */
.hero{
  position:relative;background:var(--dark);color:#fff;overflow:hidden;
  padding:96px 22px 104px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(1200px 500px at 78% -10%, rgba(230,57,70,.32), transparent 60%),
    repeating-linear-gradient(115deg, rgba(255,255,255,.03) 0 2px, transparent 2px 26px);
  pointer-events:none;
}
.hero__inner{max-width:var(--maxw);margin:0 auto;position:relative;}
.hero__eyebrow{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#cfcfcf;
  display:flex;align-items:center;gap:10px;margin-bottom:22px;font-weight:500;
}
.hero__eyebrow::before{content:"";width:34px;height:2px;background:var(--red);display:inline-block;}
.hero__title{
  font-family:"Bebas Neue",sans-serif;font-weight:400;line-height:.92;
  font-size:clamp(52px,10vw,116px);letter-spacing:.01em;margin:0 0 6px;
}
.hero__title .accent{color:var(--red);}
.hero__dates{
  font-family:"Bebas Neue",sans-serif;font-size:clamp(26px,4.5vw,44px);
  letter-spacing:.05em;color:#fff;margin:0 0 26px;
}
.hero__dates .sep{color:var(--red);padding:0 .25em;}
.hero__lead{font-size:clamp(15px,2.4vw,18px);color:#e4e4e4;max-width:620px;margin:0 0 14px;line-height:1.85;}
.hero__host{font-size:13px;color:#aaa;margin:0 0 34px;}
.hero__host strong{color:#fff;font-weight:700;}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.hero__note{font-size:12px;color:#9a9a9a;}
/* PR動画あり → 2カラム（左テキスト・右動画）。無ければ従来の単カラム */
.hero--media .hero__inner{display:grid;grid-template-columns:minmax(0,0.82fr) minmax(0,1.18fr);gap:44px;align-items:center;}
.hero__media{position:relative;}
.hero-video,.hero-yt__frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:#000;border:1px solid rgba(255,255,255,.14);box-shadow:0 16px 50px rgba(0,0,0,.45);}
.hero-video iframe,.hero-video video,.hero-yt__frame iframe,.hero-yt__frame #hero-yt-player{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;object-fit:cover;background:#000;}
/* YouTube 自作ミニ操作バー */
.hero-yt__bar{display:flex;align-items:center;gap:12px;margin-top:12px;}
.hyt-btn{width:40px;height:40px;flex:none;border:none;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s;}
.hyt-btn:hover{background:rgba(255,255,255,.26);}
.hyt-btn svg{width:18px;height:18px;}
.hyt-seek{flex:1;height:5px;accent-color:var(--red);cursor:pointer;}
@media(max-width:880px){
  .hero--media .hero__inner{grid-template-columns:1fr;gap:28px;}
}

/* ---------- ボタン ---------- */
.btn{
  display:inline-block;font-family:inherit;font-weight:700;font-size:16px;text-decoration:none;
  padding:16px 42px;border-radius:8px;border:2px solid transparent;cursor:pointer;text-align:center;
  transition:transform .08s,background .15s;
}
.btn:active{transform:translateY(1px);}
.btn--apply{background:var(--green);color:#fff;box-shadow:0 4px 0 var(--green-d);}
.btn--apply:hover{background:var(--green-d);}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4);}
.btn--ghost-light:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn--lg{font-size:18px;padding:18px 56px;}

/* ---------- セクション共通 ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:84px 22px;}
.section--tight{padding:64px 22px;}
.section--alt{background:var(--bg2);max-width:none;}
.section--alt > .section__in{max-width:var(--maxw);margin:0 auto;}
.section__head{margin-bottom:44px;}
.eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);font-weight:700;margin:0 0 10px;display:flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--red);display:inline-block;}
.h2{font-size:clamp(24px,4vw,34px);font-weight:900;line-height:1.3;margin:0;letter-spacing:.01em;}
.lead-p{font-size:16px;color:#444;line-height:1.95;max-width:760px;margin:18px 0 0;}

/* ---------- 講師 ---------- */
.instructors{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.inst{text-align:center;}
.inst__ph{
  width:100%;aspect-ratio:1;border-radius:10px;margin-bottom:14px;
  background:linear-gradient(150deg,#222,#3a3a3a);
  display:flex;align-items:center;justify-content:center;
  font-family:"Bebas Neue",sans-serif;font-size:46px;color:#5a5a5a;
  border:1px solid #ececec;
}
.inst__name{font-size:16px;font-weight:700;margin:0 0 3px;}
.inst__name .en{display:block;font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.04em;margin-top:2px;}
.inst__work{font-size:12.5px;color:var(--red-d);margin:6px 0 0;font-weight:500;}
@media(max-width:820px){ .instructors{grid-template-columns:repeat(2,1fr);gap:18px;} }

/* ---------- 含む/含まない ---------- */
.incl-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.incl{background:#fff;border:1px solid var(--line);border-radius:10px;padding:28px 28px 30px;}
.incl--no{background:#fafafa;}
.incl__h{font-size:17px;font-weight:800;margin:0 0 18px;display:flex;align-items:center;gap:10px;}
.incl__h .mk{width:24px;height:24px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:700;flex:none;}
.incl--yes .mk{background:var(--green);}
.incl--no .mk{background:#bbb;}
.incl__list{list-style:none;margin:0;padding:0;}
.incl__list li{font-size:14px;color:#3a3a3a;padding:8px 0 8px 26px;position:relative;border-bottom:1px solid #f0f0f0;}
.incl__list li:last-child{border-bottom:none;}
.incl__list li::before{position:absolute;left:2px;top:8px;font-weight:700;}
.incl--yes .incl__list li::before{content:"✓";color:var(--green);}
.incl--no .incl__list li::before{content:"—";color:#bbb;}
@media(max-width:760px){ .incl-grid{grid-template-columns:1fr;} }

/* ---------- 料金 ---------- */
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:760px;}
.price{border:1px solid var(--line);border-radius:12px;padding:32px 30px;background:#fff;text-align:center;position:relative;}
.price--feat{border:2px solid var(--red);}
.price__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:20px;letter-spacing:.04em;}
.price__label{font-size:13px;color:var(--muted);font-weight:700;margin:0 0 10px;}
.price__amt{font-family:"Bebas Neue",sans-serif;font-size:46px;line-height:1;color:var(--ink);margin:0 0 6px;letter-spacing:.02em;}
.price__sub{font-size:12px;color:var(--muted);margin:0;}
.price-note{font-size:13px;color:var(--muted);margin:20px 0 0;}
.price-note strong{color:var(--red-d);}
/* パッケージ選択／グレーアウト */
.pkg{cursor:pointer;transition:box-shadow .15s,border-color .15s,transform .08s;}
.pkg:hover{transform:translateY(-2px);}
.pkg.is-sel{border-color:var(--red);box-shadow:0 0 0 3px rgba(230,57,70,.22);}
.pkg:focus-visible{outline:2px solid var(--green);outline-offset:3px;}
.pkg--off{opacity:.5;filter:grayscale(1);pointer-events:none;}
.pkg__off{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:#777;color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:20px;white-space:nowrap;}
.pkg-hint{font-size:12.5px;color:var(--muted);margin:14px 0 0;text-align:center;}
.incl__pkg{font-size:13px;color:var(--red-d);font-weight:700;margin-left:8px;}
.pkg-incl-grid{margin-top:26px;}
@media(max-width:600px){ .price-grid{grid-template-columns:1fr;} }

/* ---------- タイムライン（日程） ---------- */
.timeline{position:relative;max-width:680px;margin:0;padding:0;list-style:none;}
.timeline::before{content:"";position:absolute;left:78px;top:6px;bottom:6px;width:2px;background:var(--line);}
.tl{position:relative;display:grid;grid-template-columns:78px 1fr;gap:22px;padding:11px 0;}
.tl__date{font-family:"Bebas Neue",sans-serif;font-size:22px;color:var(--red);text-align:right;letter-spacing:.02em;padding-top:1px;}
.tl__body{position:relative;padding-left:22px;}
.tl__body::before{content:"";position:absolute;left:-5px;top:9px;width:12px;height:12px;border-radius:50%;background:#fff;border:3px solid var(--red);}
.tl__title{font-size:15px;font-weight:700;margin:0;}
.tl__sub{font-size:12.5px;color:var(--muted);margin:2px 0 0;}
.tl--cap .tl__body::before{background:var(--red);}
.timeline-note{font-size:12.5px;color:var(--muted);margin:18px 0 0;padding-left:100px;}
@media(max-width:600px){
  .timeline::before{left:54px;}
  .tl{grid-template-columns:54px 1fr;gap:12px;}
  .tl__date{font-size:18px;}
  .timeline-note{padding-left:0;}
}

/* ---------- 応募の流れ ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step;}
.flow__item{background:#fff;border:1px solid var(--line);border-radius:10px;padding:26px 22px;position:relative;}
.flow__num{font-family:"Bebas Neue",sans-serif;font-size:34px;color:var(--red);line-height:1;margin-bottom:10px;}
.flow__t{font-size:15px;font-weight:800;margin:0 0 8px;}
.flow__d{font-size:13px;color:#555;margin:0;line-height:1.7;}
@media(max-width:820px){ .flow{grid-template-columns:1fr 1fr;} }
@media(max-width:480px){ .flow{grid-template-columns:1fr;} }

/* ---------- 参加条件 ---------- */
.req-band{background:var(--dark);color:#fff;border-radius:14px;padding:40px 40px;}
.req-band__h{font-size:20px;font-weight:800;margin:0 0 24px;}
.req-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;list-style:none;margin:0;padding:0;}
.req-list li{background:var(--dark2);border:1px solid #2c2c2c;border-radius:10px;padding:22px 20px;}
.req-list .n{font-family:"Bebas Neue",sans-serif;color:var(--red);font-size:26px;display:block;margin-bottom:8px;}
.req-list .t{font-size:15px;font-weight:700;display:block;margin-bottom:4px;}
.req-list .s{font-size:12.5px;color:#aaa;}
@media(max-width:760px){ .req-list{grid-template-columns:1fr;} }

/* ---------- 会場 ---------- */
.venue{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.venue__card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:26px 28px;}
.venue__k{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--red);font-weight:700;margin:0 0 8px;}
.venue__v{font-size:16px;font-weight:700;margin:0 0 6px;}
.venue__s{font-size:13px;color:#555;margin:0;}
@media(max-width:600px){ .venue{grid-template-columns:1fr;} }

/* ---------- 受講生の声 ---------- */
.voices{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.voice{background:#fff;border:1px solid var(--line);border-radius:10px;padding:28px 28px;position:relative;}
.voice__q{font-family:"Bebas Neue",sans-serif;font-size:50px;color:#f0d4d7;line-height:.6;height:24px;}
.voice__t{font-size:14px;color:#3a3a3a;line-height:1.9;margin:0 0 14px;}
.voice__a{font-size:12px;color:var(--muted);font-weight:700;margin:0;}
@media(max-width:600px){ .voices{grid-template-columns:1fr;} }

/* ---------- FAQ ---------- */
.faq{max-width:800px;}
.faq details{border:1px solid var(--line);border-radius:8px;margin-bottom:12px;background:#fff;overflow:hidden;}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 52px 18px 22px;font-size:15px;font-weight:700;position:relative;
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);color:var(--red);font-size:22px;font-weight:400;transition:transform .2s;}
.faq details[open] summary::after{content:"−";}
.faq__a{padding:0 22px 20px;font-size:14px;color:#444;line-height:1.9;}

/* ---------- 最終CTA ---------- */
.cta-final{background:var(--dark);color:#fff;text-align:center;padding:80px 22px;position:relative;overflow:hidden;}
.cta-final::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 50% 120%, rgba(230,57,70,.28), transparent 60%);}
.cta-final__in{position:relative;max-width:680px;margin:0 auto;}
.cta-final__t{font-family:"Bebas Neue",sans-serif;font-size:clamp(34px,6vw,60px);letter-spacing:.02em;margin:0 0 14px;line-height:1;}
.cta-final__p{font-size:15px;color:#d4d4d4;margin:0 0 30px;}

/* ---------- フッター ---------- */
.foot{background:#0d0d0d;color:#9a9a9a;}
.foot__in{max-width:var(--maxw);margin:0 auto;padding:40px 22px;}
.foot__top{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;border-bottom:1px solid #232323;padding-bottom:24px;margin-bottom:20px;}
.foot__org{color:#fff;font-weight:700;font-size:15px;margin:0 0 6px;}
.foot__logo{height:52px;width:auto;display:block;margin:0 0 14px;}
.foot__addr{font-size:12.5px;line-height:1.8;margin:0;}
.foot__links{display:flex;gap:20px;flex-wrap:wrap;align-items:flex-start;}
.foot__links a{color:#bbb;text-decoration:none;font-size:13px;}
.foot__links a:hover{color:#fff;}
.foot__copy{font-size:11px;color:#666;margin:0;}

/* ---------- アクセシビリティ ---------- */
@media(prefers-reduced-motion:reduce){ *{transition:none!important;animation:none!important;scroll-behavior:auto!important;} }
:focus-visible{outline:2px solid var(--green);outline-offset:3px;}

/* =========================================================
   管理者バー（ログイン中のみ・最上部に固定）
   ========================================================= */
#camp-adminbar{
  position:fixed;top:0;left:0;right:0;height:40px;z-index:9999;
  background:#15181d;border-bottom:2px solid var(--red);color:#cfd4da;font-size:13px;
}
.cab__in{height:100%;display:flex;align-items:center;gap:18px;padding:0 16px;}
.cab__brand{
  font-family:"Bebas Neue",sans-serif;letter-spacing:.04em;color:#fff;font-size:16px;
  display:flex;align-items:center;gap:8px;text-decoration:none;white-space:nowrap;
}
.cab__brand::before{content:"";width:4px;height:18px;background:var(--red);display:inline-block;}
.cab__nav{display:flex;gap:16px;}
.cab__nav a,.cab__right a{color:#cfd4da;text-decoration:none;white-space:nowrap;}
.cab__nav a:hover,.cab__right a:hover{color:#fff;}
.cab__btn{
  margin-left:auto;background:var(--red);color:#fff;border:none;font:inherit;font-weight:700;
  padding:7px 16px;border-radius:6px;cursor:pointer;white-space:nowrap;
}
.cab__btn:hover{background:var(--red-d);}
.cab__btn.on{background:var(--green);}
.cab__right{display:flex;align-items:center;gap:14px;}
.cab__user{color:#9aa0a6;font-size:12px;white-space:nowrap;}

/* バーのぶん全体を押し下げ、stickyナビはバーの直下に固定 */
body.has-adminbar{padding-top:40px;}
body.has-adminbar .nav{top:40px;}

@media (max-width:680px){
  #camp-adminbar{font-size:12px;}
  .cab__in{gap:10px;padding:0 10px;}
  .cab__brand{font-size:14px;}
  .cab__nav{gap:12px;}
  .cab__user{display:none;}
  .cab__btn{padding:6px 12px;}
}
