/* ══════════════════════════════════════════════════
   MOVIE PAGE — movie.css
══════════════════════════════════════════════════ */

/* ── Hero ── */
.mv-hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding:0 20px 48px;overflow:hidden}
.mv-hero-bg{position:absolute;inset:0;background:center center/cover no-repeat;z-index:0}
.mv-hero-overlay{position:absolute;inset:0;background:none;z-index:1}
.mv-hero-inner{position:relative;z-index:2;max-width:700px;background:rgba(255,255,255,.18);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:32px 28px;border-radius:var(--rd)}
.mv-breadcrumb{font-family:var(--en);font-size:11px;font-weight:600;letter-spacing:.15em;color:rgba(26,26,46,.6);margin-bottom:16px}
.mv-breadcrumb a{color:rgba(26,26,46,.6);transition:color .2s}
.mv-breadcrumb a:hover{color:var(--yellow)}
.mv-breadcrumb span{color:var(--navy)}
.mv-hero-eyebrow{display:inline-flex;align-items:center;font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.18em;color:var(--yellow);background:rgba(255,210,51,.12);border:1px solid rgba(255,210,51,.25);padding:6px 18px;border-radius:var(--rd-pill);margin-bottom:16px;text-transform:uppercase}
.mv-hero-h1{font-size:clamp(28px,7vw,52px);font-weight:900;line-height:1.25;color:var(--navy);margin-bottom:16px}
.mv-hero-sub{font-size:14px;color:rgba(26,26,46,.75);line-height:2;margin-bottom:20px}
.mv-hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.mv-hero .badge.glass{background:rgba(255,255,255,.6);border:1.5px solid rgba(26,26,46,.15);color:var(--navy);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);font-size:11px;font-weight:700;padding:7px 18px;border-radius:var(--rd-pill)}
.mv-hero-btns{display:flex;flex-direction:column;gap:10px}
.mv-hero-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--yellow);color:var(--navy);font-size:14px;font-weight:700;padding:16px 36px;border-radius:var(--rd-pill);font-family:var(--sans);transition:all .25s;box-shadow:0 6px 28px rgba(255,210,51,.4);width:100%;max-width:320px}
.mv-hero-btn:hover{background:var(--yellow-dark);transform:translateY(-2px);box-shadow:0 8px 36px rgba(255,210,51,.5)}
.mv-hero-btn svg{width:20px;height:20px;flex-shrink:0}

/* ── What We Create Menu ── */
.mv-menu{display:flex;flex-direction:column;gap:0;margin-top:32px;max-width:800px}
.mv-menu-item{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--border)}
.mv-menu-item:last-child{border-bottom:none}
.mv-menu-num{font-family:var(--en);font-size:20px;font-weight:800;color:var(--teal);flex-shrink:0;width:36px}
.mv-menu-body{flex:1}
.mv-menu-name{font-size:15px;font-weight:900;color:var(--navy);margin-bottom:2px}
.mv-menu-en{font-family:var(--en);font-size:10px;font-weight:600;letter-spacing:.12em;color:var(--gray-light);text-transform:uppercase}
.mv-menu-note{font-size:12px;color:var(--gray);flex-shrink:0;text-align:right}

/* ── Video Gallery ── */
.mv-gallery-wrap{margin-top:32px}
.mv-gallery{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;cursor:grab}
.mv-gallery:active{cursor:grabbing}
.mv-gallery::-webkit-scrollbar{display:none}
.mv-track{display:flex;gap:16px;padding-bottom:4px}
.mv-card{flex-shrink:0;width:64vw;cursor:pointer;transition:transform .22s}
.mv-card:hover{transform:translateY(-4px)}
.mv-thumb{position:relative;aspect-ratio:9/16;background:var(--gray-bg);overflow:hidden;border-radius:var(--rd);border:2px solid var(--border)}
.mv-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}
.mv-ph{position:absolute;inset:0;background:var(--gray-bg);z-index:0}
.mv-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2}
.mv-play-icon{width:48px;height:48px;border-radius:50%;background:rgba(0,0,0,.45);border:2px solid rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.9);font-size:16px;padding-left:3px;transition:all .2s}
.mv-card:hover .mv-play-icon{background:rgba(0,0,0,.7);border-color:var(--yellow);color:var(--yellow)}
.mv-dur{position:absolute;bottom:10px;right:10px;font-family:var(--en);font-size:10px;letter-spacing:.08em;color:var(--white);background:rgba(0,0,0,.6);padding:3px 8px;border-radius:4px;z-index:2}
.mv-meta{padding:12px 0 2px}
.mv-label{font-size:12px;font-weight:700;color:var(--navy)}

/* ── Modal ── */
.mv-modal{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.92);align-items:center;justify-content:center}
.mv-modal.mv-open{display:flex}
.mv-modal-body{position:relative;width:min(88vw,360px)}
.mv-modal-video{width:100%;aspect-ratio:9/16;object-fit:contain;background:#000;display:block;max-height:82vh}
.mv-close-btn{position:absolute;top:-44px;right:0;background:none;border:none;color:rgba(255,255,255,.7);font-size:28px;cursor:pointer;line-height:1;padding:4px 8px}
.mv-close-btn:hover{color:#fff}

/* ── Plans ── */
.mv-plans-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:32px}
.mv-plan-card{position:relative;background:var(--white);border:2px solid var(--border);border-radius:var(--rd);padding:24px 20px;transition:border-color .3s}
.mv-plan-card:hover{border-color:var(--teal)}
.mv-plan-featured{border-color:var(--teal);box-shadow:0 4px 24px rgba(0,150,136,.1)}
.mv-plan-badge{position:absolute;top:-10px;left:20px;background:var(--teal);color:var(--white);font-family:var(--en);font-size:9px;font-weight:700;letter-spacing:.15em;padding:4px 14px;border-radius:var(--rd-pill)}
.mv-plan-tag{font-family:var(--en);font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--teal);margin-bottom:6px}
.mv-plan-dur{font-size:16px;font-weight:900;color:var(--navy);margin-bottom:4px}
.mv-plan-detail{font-size:12px;color:var(--gray);margin-bottom:12px}
.mv-plan-price{font-family:var(--en);font-size:28px;font-weight:800;color:var(--teal)}
.mv-plan-price small{font-size:11px;font-weight:500;color:var(--gray-light);margin-left:4px}

/* ── How It Works ── */
.mv-steps{display:flex;flex-direction:column;gap:0;margin-top:32px;max-width:800px}
.mv-step{display:flex;gap:16px;padding:24px 0;border-bottom:1px solid var(--border)}
.mv-step:last-child{border-bottom:none}
.mv-step-num{font-family:var(--en);font-size:20px;font-weight:800;color:var(--teal);flex-shrink:0;width:36px}
.mv-step-body{flex:1}
.mv-step-title{font-size:15px;font-weight:900;color:var(--navy);margin-bottom:6px}
.mv-step-text{font-size:13px;color:var(--gray);line-height:2}

/* ── CTA ── */
.mv-cta-btns{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:32px}
.mv-cta-line{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:#06C755;color:var(--white);font-size:16px;font-weight:900;padding:18px 44px;border-radius:var(--rd-pill);transition:all .25s;box-shadow:0 4px 20px rgba(6,199,85,.3)}
.mv-cta-line:hover{background:#05b04c;transform:translateY(-2px);box-shadow:0 8px 32px rgba(6,199,85,.4)}
.mv-cta-line svg{flex-shrink:0;fill:currentColor}
.mv-cta-back{font-size:13px;color:var(--gray);font-weight:600;border-bottom:1px dashed var(--border);padding-bottom:2px;transition:color .2s}
.mv-cta-back:hover{color:var(--teal)}
.mv-cta-note{font-size:11px;color:var(--gray-light);margin-top:20px}

/* ══ PC ══ */
@media(min-width:768px){
  .mv-hero{padding:0 6% 64px}
  .mv-hero-h1{font-size:clamp(36px,4.5vw,52px)}
  .mv-hero-sub{font-size:16px}
  .mv-hero-btn{width:auto;max-width:none}
  .mv-card{width:calc(25% - 12px)}
  .mv-menu-item{gap:24px;padding:24px 0}
  .mv-menu-name{font-size:17px}
  .mv-menu-note{font-size:13px}
  .mv-plans-grid{grid-template-columns:repeat(4,1fr);gap:20px}
  .mv-plan-price{font-size:24px}
  .mv-step{gap:24px;padding:28px 0}
  .mv-step-title{font-size:17px}
  .mv-cta-line{font-size:18px;padding:20px 56px}
  .mv-modal-body{width:min(46vh,320px)}
}

/* ══ SP ══ */
@media(max-width:767px){
  .mv-hero{padding:0 16px 32px;min-height:70svh}
  .mv-hero-bg{background-position:60% center}
  .mv-hero-inner{width:100%;max-width:280px;margin-left:0;margin-right:auto;padding:22px 20px;border-radius:18px;background:rgba(255,255,255,.10);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
  .mv-hero-h1{font-size:clamp(24px,7vw,36px)}
  .mv-hero-eyebrow{font-size:9px;padding:4px 14px}
  .mv-hero-sub{font-size:12px}
  .mv-hero .badge.glass{font-size:10px;padding:5px 14px}
  .mv-hero-btn{font-size:13px;padding:12px 28px;max-width:280px}
  .mv-card{width:64vw}
  .mv-menu-item{flex-wrap:wrap;gap:8px;padding:14px 0}
  .mv-menu-num{font-size:16px;width:28px}
  .mv-menu-name{font-size:13px}
  .mv-menu-note{flex-basis:100%;text-align:left;padding-left:44px;font-size:11px}
  #mv-whatwecreate .mv-menu{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:none}
  #mv-whatwecreate .mv-menu-item{display:grid;grid-template-areas:"thumb thumb" "num body" "note note";grid-template-columns:auto 1fr;gap:6px 8px;border-bottom:none;padding:0;align-items:start}
  #mv-whatwecreate .mv-menu-thumb{grid-area:thumb}
  #mv-whatwecreate .mv-menu-num{grid-area:num;align-self:center;font-size:14px;width:24px}
  #mv-whatwecreate .mv-menu-body{grid-area:body}
  #mv-whatwecreate .mv-menu-en{display:none}
  #mv-whatwecreate .mv-menu-name{font-size:12px;line-height:1.4}
  #mv-whatwecreate .mv-menu-note{grid-area:note;padding-left:0;text-align:left;font-size:10px;line-height:1.6}
  .mv-plans-grid{grid-template-columns:1fr 1fr;gap:10px}
  .mv-plan-card{padding:18px 14px}
  .mv-plan-dur{font-size:14px}
  .mv-plan-price{font-size:20px}
  .mv-plan-price small{font-size:9px}
  .mv-step{gap:10px;padding:16px 0}
  .mv-step-num{font-size:16px;width:28px}
  .mv-step-title{font-size:13px}
  .mv-step-text{font-size:11px}
  .mv-cta-line{font-size:14px;padding:14px 32px}
  .mv-cta-note{font-size:9px}
}

/* ── Shooting Option ── */
.mv-shoot-media{margin-top:28px}
.mv-shoot-visual{aspect-ratio:3/4;overflow:hidden;border-radius:var(--rd);background:#f3efe6}
.mv-shoot-visual img{width:100%;height:100%;object-fit:cover;display:block}
.mv-shoot-card{background:var(--white);border:2px solid var(--teal);border-radius:var(--rd);padding:24px 22px;margin-top:28px;max-width:720px;margin-left:auto;margin-right:auto}
.mv-shoot-row{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid var(--border);align-items:flex-start}
.mv-shoot-row:last-child{border-bottom:none}
.mv-shoot-label{font-size:12px;font-weight:700;color:var(--teal);flex-shrink:0;width:90px;padding-top:2px}
.mv-shoot-value{font-size:14px;font-weight:700;color:var(--navy);line-height:1.6;flex:1}
.mv-shoot-value small{font-size:11px;font-weight:500;color:var(--gray);margin-left:6px}
.mv-shoot-btns{display:flex;justify-content:center;margin-top:24px}
.mv-shoot-line{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:#06C755;color:var(--white);font-size:14px;font-weight:900;padding:16px 32px;border-radius:var(--rd-pill);transition:all .25s;box-shadow:0 4px 20px rgba(6,199,85,.3)}
.mv-shoot-line:hover{background:#05b04c;transform:translateY(-2px);box-shadow:0 8px 32px rgba(6,199,85,.4)}
.mv-shoot-line svg{flex-shrink:0;fill:currentColor}

@media(min-width:768px){
  .mv-shoot-media{display:flex;gap:28px;align-items:stretch}
  .mv-shoot-visual{flex:0 0 34%;aspect-ratio:auto;height:100%;width:100%;align-self:stretch;overflow:hidden}
  .mv-shoot-visual img{width:100%!important;height:100%!important;aspect-ratio:auto!important;object-fit:cover;object-position:top center;display:block}
  #mv-shoot .mv-shoot-card{flex:1;margin-top:0;max-width:none}
  .mv-shoot-card{padding:32px 28px}
  .mv-shoot-row{padding:18px 0;gap:24px}
  .mv-shoot-label{width:120px;font-size:13px}
  .mv-shoot-value{font-size:15px}
  .mv-shoot-line{font-size:15px;padding:18px 40px}
}

@media(max-width:767px){
  .mv-shoot-media{display:grid;grid-template-columns:40% 60%;gap:12px;align-items:stretch}
  .mv-shoot-visual{max-width:none;margin:0;width:100%;height:100%;aspect-ratio:auto;align-self:stretch;overflow:hidden}
  .mv-shoot-visual img{width:100%!important;height:100%!important;aspect-ratio:auto!important;object-fit:cover;object-position:top center;display:block}
  #mv-shoot .mv-shoot-card{margin-top:0;width:100%;max-width:none;padding:14px 10px}
  .mv-shoot-card{padding:20px 16px}
  .mv-shoot-row{flex-direction:column;gap:4px;padding:12px 0}
  .mv-shoot-label{width:auto;font-size:11px}
  .mv-shoot-value{font-size:13px}
  .mv-shoot-value small{display:block;margin-left:0;margin-top:2px}
  .mv-shoot-line{font-size:13px;padding:14px 24px}
}

/* ── Why Us ── */
.mv-why-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:32px}
.mv-why-card{background:var(--white);border:2px solid var(--border);border-radius:var(--rd);padding:24px 22px;display:flex;align-items:flex-start;gap:16px;transition:border-color .3s}
.mv-why-card:hover{border-color:var(--teal)}
.mv-why-num{font-family:var(--en);font-size:22px;font-weight:800;color:var(--teal);flex-shrink:0;line-height:1}
.mv-why-body{flex:1}
.mv-why-title{font-size:15px;font-weight:900;color:var(--navy);line-height:1.5;margin-bottom:8px}
.mv-why-text{font-size:13px;color:var(--gray);line-height:1.8}

@media(min-width:768px){
  .mv-why-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .mv-why-card{flex-direction:column;padding:28px 24px;gap:14px}
  .mv-why-num{font-size:24px}
  .mv-why-title{font-size:16px}
  .mv-why-text{font-size:13px}
}

@media(max-width:767px){
  .mv-why-card{padding:18px 16px;gap:12px}
  .mv-why-num{font-size:18px}
  .mv-why-title{font-size:13px;margin-bottom:4px}
  .mv-why-text{font-size:11px;line-height:1.7}
}

/* ── Stats ── */
.mv-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.mv-stats-item{background:var(--white);border:2px solid var(--border);border-radius:var(--rd);padding:22px 18px;text-align:center;transition:border-color .3s}
.mv-stats-item:hover{border-color:var(--teal)}
.mv-stats-num{font-family:var(--en);font-size:36px;font-weight:800;color:var(--teal);line-height:1;margin-bottom:8px}
.mv-stats-unit{font-size:13px;font-weight:700;color:var(--navy);margin-left:4px}
.mv-stats-label{font-size:13px;font-weight:900;color:var(--navy);margin-bottom:6px}
.mv-stats-sub{font-size:10px;color:var(--gray);line-height:1.6}

@media(min-width:768px){
  .mv-stats-grid{grid-template-columns:repeat(4,1fr);gap:20px}
  .mv-stats-item{padding:28px 20px}
  .mv-stats-num{font-size:44px}
  .mv-stats-unit{font-size:14px}
  .mv-stats-label{font-size:14px}
  .mv-stats-sub{font-size:11px}
}

@media(max-width:767px){
  .mv-stats-item{padding:18px 12px}
  .mv-stats-num{font-size:28px}
  .mv-stats-unit{font-size:11px}
  .mv-stats-label{font-size:11px}
  .mv-stats-sub{font-size:9px;line-height:1.5}
}

/* ── How We Edit Thumbs ── */
.mv-menu-thumb{aspect-ratio:1/1;width:100%;overflow:hidden;border-radius:var(--rd);background:#f3efe6}
.mv-menu-thumb img{width:100%;height:100%;object-fit:cover;display:block}

@media(min-width:768px){
  #mv-whatwecreate .mv-menu{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:none}
  #mv-whatwecreate .mv-menu-item{flex-direction:column;align-items:flex-start;border-bottom:none;padding:0;gap:10px}
  #mv-whatwecreate .mv-menu-note{flex-basis:auto;text-align:left;padding-left:0;font-size:12px}
}

/* ── Section padding ── */
.sec, .sec-faq { padding-top: 44px; padding-bottom: 44px; }
@media (min-width: 768px) {
  .sec, .sec-faq { padding-top: 68px; padding-bottom: 68px; }
}
@media (min-width: 1200px) {
  .sec, .sec-faq { padding-top: 80px; padding-bottom: 80px; }
}
@media (max-width: 767px) {
  .sec { padding-top: 32px; padding-bottom: 32px; }
  .sec-faq { padding-top: 24px !important; padding-bottom: 24px !important; }
}

/* ── How It Works 2カラム ── */
.mv-flow-wrap{display:block}
.mv-flow-visual{display:none}

@media(min-width:768px){
  .mv-flow-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
  .mv-flow-left .sec-title{text-align:left}
  #mv-flow .mv-steps{max-width:none}
  .mv-flow-visual{display:block;height:100%;align-self:stretch;width:100%;overflow:hidden;border-radius:var(--rd);background:#f3efe6}
  .mv-flow-visual img{width:100%!important;height:100%!important;aspect-ratio:auto!important;object-fit:cover;object-position:top center;display:block}
}

/* ── PC/SP 切り替えユーティリティ ── */
.pc-only { display: inline; }
.sp-only { display: none; }
@media (max-width: 767px) {
  .pc-only { display: none !important; }
  .sp-only { display: inline !important; }
}

/* ── FAQ 2列レイアウト ── */
.faq-2col{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch;max-width:none;width:100%}
.faq-2col>.faq-item2{height:100%}

@media(max-width:767px){
  .faq-2col{grid-template-columns:1fr;gap:12px;align-items:start}
  .faq-2col>.faq-item2{height:auto}
}
