/* =========================================================
   エムサイト工房 LP v3
   ブランドはv2を継承（主役=ブルー / 差し色=sun黄 / Zen Maru Gothic）。
   v3では研究員の競合LP分析（分析DB lp 10件）で得た「構成の型」に組み替え：
   FVでノーリスク明示 / 実物デモを早く / 節目ごとにCTA反復 / ページ内フォーム完結。
   ========================================================= */
:root{
  --brand:#2A93E0;        /* 主役ブルー */
  --brand-deep:#155C9E;   /* 濃ブルー */
  --navy:#122E4A;         /* ネイビー */
  --sky:#E9F4FD;          /* 空色（薄） */
  --paper:#F8FBFE;        /* 用紙 */
  --sun:#FFC24B;          /* 差し色（黄） */
  --coral:#FF8A6B;        /* アクセント（珊瑚） */
  --ink:#16314E;          /* 本文インク */
  --sky-2:#BFE0F7;
  --sky-soft:#F2F8FE;
  --line:#E4EFF9;
  --line-2:#DCEAF7;
  --text:#3A5572;
  --muted:#5B708A;
  --navy-900:#0C2238;
  --gold:#E8A93B;
  --r-card:18px;
  --r-xl:28px;
  --surf-card:linear-gradient(180deg,#fff,#F8FBFE);
  --shadow-card:0 1px 2px rgba(18,46,74,.06),0 18px 40px -22px rgba(18,46,74,.26);
  --shadow-card-hover:0 2px 4px rgba(18,46,74,.07),0 30px 60px -24px rgba(18,46,74,.32);
  --shadow-cta:0 1px 2px rgba(18,46,74,.12),0 16px 30px -10px rgba(42,147,224,.55);
  --edge-hi:inset 0 1px 0 rgba(255,255,255,.7);
  --font-disp:'Zen Maru Gothic',sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  font-family:'Noto Sans JP',sans-serif;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--sun);color:var(--navy)}
img{max-width:100%}
a{color:inherit}

/* Lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

/* =========================================================
   キーフレーム＆ ambient装飾（inlineでなくクラス化 → reduce-motionで一括制御）
   ========================================================= */
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}
@keyframes floatY2{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-9px) rotate(4deg)}}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes wag{0%,100%{transform:rotate(-14deg)}50%{transform:rotate(20deg)}}
@keyframes blink{0%,93%,100%{transform:scaleY(1)}96.5%{transform:scaleY(.08)}}
@keyframes wave{0%,100%{transform:rotate(14deg)}50%{transform:rotate(-26deg)}}
@keyframes sparkle{0%,100%{opacity:.25;transform:scale(.7) rotate(0)}50%{opacity:1;transform:scale(1.15) rotate(25deg)}}
.fx-float{animation:floatY 6.5s ease-in-out infinite}
.fx-float2{animation:floatY2 7s ease-in-out infinite}
.fx-sparkle{animation:sparkle 3.2s ease-in-out infinite}
.fx-sparkle-slow{animation:sparkle 4.1s .6s ease-in-out infinite}
.ambient{position:absolute;inset:0;overflow:hidden;pointer-events:none}

/* reveal 初期状態（JS有効時のみ隠す → JS未読込でも内容が見えるフォールバック） */
.js [data-reveal]{opacity:0;will-change:transform,opacity}

/* =========================================================
   レイアウト共通
   ========================================================= */
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.sec{position:relative;overflow:hidden;padding:96px 24px}
.sec-head{position:relative;text-align:center;margin-bottom:44px}
.eyebrow{font-family:var(--font-disp);font-weight:700;color:var(--brand);font-size:15px;margin-bottom:10px}
.h2{margin:0;font-family:var(--font-disp);font-weight:900;font-size:36px;color:var(--navy);line-height:1.4}
.sub{margin:10px 0 0;color:var(--muted);font-size:15px;line-height:1.8}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* カード共通 */
.card{background:var(--surf-card);border:1px solid var(--line);border-radius:var(--r-card);padding:24px;box-shadow:var(--shadow-card),var(--edge-hi)}
.lift{transition:transform .4s cubic-bezier(.34,1.4,.5,1),box-shadow .4s}
.lift:hover{transform:translateY(-6px);box-shadow:var(--shadow-card-hover)}
.icon-chip{flex:none;width:46px;height:46px;border-radius:13px;background:var(--sky);display:flex;align-items:center;justify-content:center;color:var(--brand)}
.card-title{font-family:var(--font-disp);font-weight:700;font-size:18px;color:var(--navy);margin-bottom:6px}
.card-text{font-size:14px;line-height:1.75;color:var(--muted)}

/* CTA */
.cta-btn{display:inline-block;font-family:var(--font-disp);font-weight:700;text-decoration:none;border-radius:999px;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.cta-btn:hover{transform:translateY(-4px) scale(1.03)}
.cta-primary{background:linear-gradient(180deg,var(--brand),var(--brand-deep));color:#fff;font-size:17px;padding:16px 30px;box-shadow:var(--shadow-cta),var(--edge-hi)}
.cta-sun{background:var(--sun);color:var(--navy);font-size:17px;padding:16px 30px;box-shadow:0 16px 30px -10px rgba(0,0,0,.25)}
.cta-ghost{display:inline-block;background:#fff;color:var(--brand-deep);border:2px solid var(--line-2);font-family:var(--font-disp);font-weight:700;font-size:17px;text-decoration:none;padding:14px 28px;border-radius:999px;transition:all .25s}
.cta-ghost:hover{background:#fff;border-color:var(--brand);color:var(--brand-deep)}
/* 節目CTAバンド（分析：高スコアLPはセクションの節目ごとに同一CTAを反復） */
.cta-band{margin-top:44px;text-align:center;background:linear-gradient(120deg,var(--brand),var(--brand-deep));border-radius:22px;padding:34px 28px;color:#fff;box-shadow:0 24px 48px -20px rgba(42,147,224,.6)}
.cta-band .band-copy{font-family:var(--font-disp);font-weight:900;font-size:26px;line-height:1.5;margin-bottom:18px}

/* ノーリスク3チップ（分析：FVで「ベネフィット＋ノーリスク条件」同時提示が高スコアの共通項） */
.promise{display:flex;gap:10px;flex-wrap:wrap}
.promise-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surf-card);border:1.5px solid var(--line-2);
  padding:9px 16px;border-radius:999px;font-family:var(--font-disp);font-weight:700;font-size:14px;color:var(--brand-deep);
  box-shadow:var(--shadow-card),var(--edge-hi)}
.promise-chip svg{flex:none}

/* ナビ */
.nav-link{position:relative;font-family:var(--font-disp);font-weight:700;font-size:15px;color:var(--ink);text-decoration:none;transition:color .25s}
.nav-link:hover{color:var(--brand)}
.nav-underline{position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--brand);transition:width .3s cubic-bezier(.34,1.56,.64,1)}
.nav-link:hover .nav-underline{width:100%}

/* 会話（キャラの掛け合い） */
.conv{max-width:680px;margin:0 auto 46px;display:flex;flex-direction:column;gap:16px}
.conv-row{display:flex;gap:13px;align-items:flex-end}
.conv-row.rev{flex-direction:row-reverse}
.conv-av{flex:none;width:54px;height:54px}
.bub{border-radius:18px 18px 18px 5px;padding:13px 17px;font-size:15px;font-weight:500;line-height:1.6;background:var(--sky-soft);border:2px solid var(--line-2)}
.conv-row.rev .bub{border-radius:18px 18px 5px 18px;background:var(--sky);border-color:var(--sky-2)}

/* 吹き出し（ヒーロー・イントロ用テール付き） */
.speech{position:relative}
.speech::after{content:"";position:absolute;width:15px;height:15px;background:var(--tail-bg);transform:rotate(45deg);pointer-events:none}
.speech-down::after{bottom:-8px;left:var(--tail-x);border-right:2px solid var(--tail-border);border-bottom:2px solid var(--tail-border)}
.speech-right::after{right:-8px;top:calc(50% - 8px);border-top:2px solid var(--tail-border);border-right:2px solid var(--tail-border)}
.speech-staff{--tail-bg:#F8FBFE;--tail-border:var(--line-2);--tail-x:68%}
.speech-dog{--tail-bg:var(--sky);--tail-border:var(--sky-2);--tail-x:30%}
.speech-intro{--tail-bg:#fff;--tail-border:#fff}

/* =========================================================
   制作例（実物スクショカード）
   分析：完成イメージを早く見せるLPが最高スコア（notema 84）。
   v2のダミーグラデカードをやめ、実際の制作画面を見せる。
   ========================================================= */
.works-track{display:flex;gap:24px;overflow-x:auto;padding:30px max(24px,calc((100% - 1080px)/2 + 24px));
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.works-track::-webkit-scrollbar{height:8px}
.works-track::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px}
.work-card{scroll-snap-align:center;flex:none;width:330px;text-decoration:none;border-radius:22px;overflow:hidden;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-card);
  transition:transform .45s cubic-bezier(.34,1.4,.5,1),box-shadow .45s}
.work-card:hover{transform:translateY(-14px) rotate(-1deg);box-shadow:0 30px 60px -18px rgba(18,46,74,.32)}
.work-shot{position:relative;height:210px;overflow:hidden;background:var(--sky-soft)}
.work-shot img{width:100%;height:100%;object-fit:cover;object-position:top;display:block;transition:transform .6s ease}
.work-card:hover .work-shot img{transform:scale(1.05)}
.work-meta{padding:18px 22px 22px}
.work-name{font-family:var(--font-disp);font-weight:700;font-size:17px;color:var(--navy)}
.work-genre{margin-top:4px;font-size:13px;color:var(--muted)}
/* 「次はあなたのお店」招待カード */
.work-card.invite{border:2px dashed var(--sky-2);background:var(--sky-soft);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:298px;text-align:center;padding:24px}
.work-card.invite .work-name{color:var(--brand-deep)}

/* =========================================================
   比較（自分でやると／エムサイト工房なら）
   分析：比較表で判断材料を渡すLPが高評価（subscreate 82・tetasc 76）
   ========================================================= */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch}
.compare-col{border-radius:var(--r-card);padding:28px 26px}
.compare-col.self{background:#fff;border:1.5px dashed var(--line-2)}
.compare-col.us{background:linear-gradient(160deg,var(--brand),var(--brand-deep));color:#fff;box-shadow:var(--shadow-card)}
.compare-title{font-family:var(--font-disp);font-weight:900;font-size:20px;margin-bottom:16px}
.compare-col.self .compare-title{color:var(--muted)}
.compare-li{display:flex;gap:10px;align-items:flex-start;font-size:14px;line-height:1.7;margin-bottom:11px}
.compare-col.self .compare-li{color:var(--muted)}
.compare-col.us .compare-li{color:#EAF4FD}
.compare-li svg{flex:none;margin-top:3px}

/* =========================================================
   料金プラン
   ========================================================= */
.plan-card{position:relative;background:var(--paper);border:2px solid var(--line);border-radius:22px;padding:32px 26px;
  display:flex;flex-direction:column;box-shadow:var(--shadow-card),var(--edge-hi);
  transition:opacity .6s,transform .45s cubic-bezier(.34,1.4,.5,1),box-shadow .45s}
.plan-card:hover{transform:translateY(-8px);box-shadow:0 24px 48px -20px rgba(18,46,74,.28)}
.plan-card.featured{background:linear-gradient(160deg,var(--brand),var(--brand-deep));border-color:var(--brand-deep);color:#fff}
.plan-pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--sun);color:var(--navy);
  font-family:var(--font-disp);font-weight:700;font-size:12px;padding:5px 16px;border-radius:999px;white-space:nowrap;
  box-shadow:0 8px 16px -6px rgba(255,194,75,.7)}
.plan-name{font-family:var(--font-disp);font-weight:700;font-size:18px;color:var(--navy)}
.plan-card.featured .plan-name{color:#fff}
.plan-price{margin:14px 0 4px;display:flex;align-items:baseline;gap:3px;color:var(--navy)}
.plan-card.featured .plan-price{color:#fff}
.plan-price .yen{font-size:15px;font-weight:700}
.plan-price .num{font-family:var(--font-disp);font-weight:900;font-size:40px;line-height:1}
.plan-price .per{font-size:14px;opacity:.7}
/* 分析：「どんな店がどのプラン向きか」の一言ガイドが競合に無い＝差別化点（web-maikerの弱点） */
.plan-for{display:flex;gap:8px;align-items:flex-start;background:rgba(255,194,75,.16);border-radius:12px;
  padding:10px 13px;font-size:13px;line-height:1.6;color:var(--brand-deep);font-weight:700;margin-bottom:16px}
.plan-card.featured .plan-for{background:rgba(255,255,255,.16);color:#FFE9BF}
.plan-desc{font-size:13px;color:var(--muted);margin-bottom:14px;line-height:1.6}
.plan-card.featured .plan-desc{color:var(--sky)}
.plan-feats{display:flex;flex-direction:column;gap:11px;margin-bottom:26px}
.plan-feat{display:flex;gap:9px;align-items:flex-start;font-size:14px;color:var(--text);line-height:1.5}
.plan-card.featured .plan-feat{color:#EAF4FD}
.plan-feat svg{flex:none;margin-top:1px;color:var(--brand)}
.plan-card.featured .plan-feat svg{color:var(--sun)}
.plan-cta{margin-top:auto;text-align:center;text-decoration:none;font-family:var(--font-disp);font-weight:700;font-size:15px;
  padding:13px;border-radius:999px;background:#fff;color:var(--brand-deep);border:2px solid var(--line-2)}
.plan-card.featured .plan-cta{background:var(--sun);color:var(--navy);border-color:var(--sun)}

/* フロー */
.flow-step{display:flex;gap:20px;align-items:center;padding:22px 26px}
.flow-num{flex:none;width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-deep));
  color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-weight:900;font-size:22px}
.flow-title{font-family:var(--font-disp);font-weight:700;font-size:19px;color:var(--navy)}
.flow-text{margin-top:3px;font-size:14px;color:var(--muted);line-height:1.6}

/* FAQ */
.faq-item{background:var(--surf-card);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-card)}
.faq-q{cursor:pointer;display:flex;gap:14px;align-items:center;padding:20px 22px;transition:background .2s}
.faq-q:hover{background:var(--sky-soft)}
.faq-q .q-mark{flex:none;font-family:var(--font-disp);font-weight:900;color:var(--brand);font-size:18px}
.faq-q .q-text{flex:1;font-family:var(--font-disp);font-weight:700;font-size:16px;color:var(--navy)}
.faq-chevron{flex:none;color:var(--brand);transition:transform .3s}
.faq-item.open .faq-chevron{transform:rotate(180deg)}
.faq-a{overflow:hidden;max-height:0;opacity:0;transition:max-height .4s ease,opacity .35s ease,padding .4s ease;
  padding:0 22px 0 52px;font-size:14px;line-height:1.85;color:var(--text)}
.faq-item.open .faq-a{opacity:1}

/* =========================================================
   お問い合わせフォーム
   分析：フォーム無し/電話導線無しが離脱要因として頻出（tetasc・GIG）。
   ページ内完結＋必須2項目だけ（入力過多＝摩擦、電話番号必須は避ける）。
   ========================================================= */
.form-card{background:#fff;border-radius:var(--r-xl);padding:36px 32px;box-shadow:0 30px 70px -30px rgba(12,34,56,.5);
  color:var(--ink);text-align:left;max-width:560px;margin:0 auto}
.form-row{margin-bottom:18px}
.form-label{display:block;font-family:var(--font-disp);font-weight:700;font-size:14px;color:var(--navy);margin-bottom:7px}
.form-label .req{display:inline-block;margin-left:7px;background:var(--coral);color:#fff;font-size:11px;padding:2px 8px;border-radius:999px;vertical-align:1px}
.form-label .opt{display:inline-block;margin-left:7px;background:var(--sky);color:var(--brand-deep);font-size:11px;padding:2px 8px;border-radius:999px;vertical-align:1px}
.form-input,.form-textarea{width:100%;border:2px solid var(--line-2);border-radius:14px;padding:13px 15px;font-size:15px;
  font-family:'Noto Sans JP',sans-serif;color:var(--ink);background:var(--paper);outline:none;transition:border-color .25s}
.form-input:focus,.form-textarea:focus{border-color:var(--brand)}
.form-textarea{min-height:110px;resize:vertical}
.form-note{font-size:12.5px;color:var(--muted);line-height:1.7;margin-top:14px}
.form-submit{width:100%;border:none;cursor:pointer;font-family:var(--font-disp);font-weight:700;font-size:17px;
  padding:16px;border-radius:999px;background:linear-gradient(180deg,var(--brand),var(--brand-deep));color:#fff;
  box-shadow:var(--shadow-cta),var(--edge-hi);transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.form-submit:hover{transform:translateY(-3px) scale(1.02)}
.form-submit[disabled]{opacity:.6;cursor:wait;transform:none}
.form-status{display:none;margin-top:14px;border-radius:14px;padding:14px 16px;font-size:14px;line-height:1.7;font-weight:500}
.form-status.ok{display:block;background:#EAF8EE;color:#1D6B3C;border:1.5px solid #BFE5CC}
.form-status.ng{display:block;background:#FDF0EC;color:#9C3A22;border:1.5px solid #F5CFC2}

/* イントロ（JS有効時のみ表示 → JS無効でもページを覆わないフォールバック） */
#intro{display:none}
.js #intro{position:fixed;inset:0;z-index:9000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;cursor:pointer;
  background:radial-gradient(120% 120% at 50% 30%,var(--sky) 0%,#BFE0F7 55%,var(--brand) 130%)}
#wipe{position:fixed;inset:0;z-index:8900;background:linear-gradient(180deg,var(--sky),#BFE0F7);transform:translateY(0);pointer-events:none}

/* ページTOP / ハンバーガー / モバイルメニュー */
.to-top{position:fixed;right:18px;bottom:18px;z-index:300;width:48px;height:48px;border:none;border-radius:50%;
  background:linear-gradient(180deg,var(--brand),var(--brand-deep));color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-cta),var(--edge-hi);
  opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .3s,transform .3s}
.to-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
.to-top:hover{transform:translateY(-3px)}

.nav-burger{display:none;flex:none;width:46px;height:46px;border:1px solid var(--line-2);border-radius:12px;background:#fff;
  cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0}
.nav-burger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s,opacity .2s}
.nav-burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.active span:nth-child(2){opacity:0}
.nav-burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{display:none;flex-direction:column;background:rgba(248,251,254,.97);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);padding:0 20px;max-height:0;overflow:hidden;transition:max-height .35s ease}
.mobile-menu.open{max-height:430px}
.mobile-menu a{font-family:var(--font-disp);font-weight:700;font-size:16px;color:var(--ink);text-decoration:none;padding:15px 6px;border-bottom:1px solid var(--line)}
.mobile-menu .mobile-cta{margin:14px 0 18px;text-align:center;background:var(--sun);color:var(--navy);border:none;border-radius:999px;padding:15px;box-shadow:0 8px 18px -6px rgba(255,194,75,.7)}

/* スマホ下部固定CTA（分析：CTA反復。ヒーロー通過後にだけ出す） */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:290;display:none;padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(248,251,254,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line-2);
  transform:translateY(110%);transition:transform .35s ease}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta a{display:block;text-align:center;background:var(--sun);color:var(--navy);font-family:var(--font-disp);
  font-weight:700;font-size:16px;text-decoration:none;padding:14px;border-radius:999px;box-shadow:0 10px 22px -8px rgba(255,194,75,.8)}

/* =========================================================
   レスポンシブ
   ========================================================= */
@media (max-width:880px){
  .sec{padding:72px 20px}
  .hero-grid{grid-template-columns:1fr!important;text-align:center}
  .hero-copy{align-items:center!important}
  .hero-cta{justify-content:center!important}
  .promise{justify-content:center}
  .nav-links{display:none!important}
  .header-cta{display:none!important}
  .nav-burger{display:flex}
  .mobile-menu{display:flex}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .compare{grid-template-columns:1fr}
  .h1{font-size:26px!important}
  .h2{font-size:27px}
  .conv{margin-left:auto;margin-right:auto}
  .works-track{padding-left:20px;padding-right:20px}
  .hero-scene{min-height:auto!important;margin-top:6px}
  .hero-scene [data-char="staff"]{width:150px!important}
  .hero-scene [data-char="dog"]{width:120px!important;margin-left:-18px!important}
  .hero-bubble{display:none!important}
  .sticky-cta{display:block}
  .to-top{bottom:84px}   /* 下部固定CTAと重ねない */
}

/* =========================================================
   prefers-reduced-motion
   方針（CLAUDE.md準拠）：全停止はしない。
   - 残す：reveal等のやさしいフェード、FAQ開閉、ホバー反応
   - 止める：無限ループ（浮遊・きらめき・しっぽ等）、パララックス、
     ピン留め横スクロール、イントロ大演出、Lenis慣性（JS側で分岐）
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  .fx-float,.fx-float2,.fx-sparkle,.fx-sparkle-slow{animation:none}
  [data-char] svg *{animation:none!important}
  .hero-bubble{animation:none!important}
}
