@charset "UTF-8";
/* ============================================================
   男性向けエラ取り注射 かんたん診断LP  /  mcc-lazer-hr.com/lp-era/
   スマホ専用設計（デスクトップは対象外）
   悩みの自分ごと化 → 診断 → 診断結果 → 価格 → 不安解消 の構成
   ============================================================ */

:root{
  --black:#1a1a1a;
  --ink:#262626;
  --red:#d6303a;
  --red-dark:#a8222b;
  --yellow:#ffe34d;
  --yellow-mark:#ffe863;
  --green:#1aa64b;
  --green-dark:#13853c;
  --gray-bg:#f4f4f3;
  --line:#e2e2e0;
  --maxw:480px;
  --font-ja:system-ui,-apple-system,BlinkMacSystemFont,"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;}

html,body{
  font-family:var(--font-ja);
  color:var(--ink);
  background:#e6e6e6;
  line-height:1.75;
  -webkit-text-size-adjust:100%;
}
body{font-size:16px;}

img{display:block;width:100%;height:auto;}
a{color:inherit;}

/* ===== レイアウト ===== */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  background:#fff;
}
section{padding:30px 18px;}

/* ===== 共通：見出し・強調 ===== */
.sec-title{
  font-size:23px;font-weight:900;line-height:1.45;
  text-align:center;margin-bottom:18px;
}
.hl-yellow{
  background:linear-gradient(transparent 58%, var(--yellow-mark) 58%);
  font-weight:900;
}

/* ===== 共通CTAボタン ===== */
.cta-btn{
  display:block;text-decoration:none;text-align:center;
  background:var(--green);color:#fff;font-weight:900;font-size:18px;
  line-height:1.4;
  padding:17px 14px;border-radius:12px;
  box-shadow:0 4px 0 var(--green-dark);
  margin:0 auto;max-width:380px;
}
.cta-btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--green-dark);}
.cta-btn-lg{font-size:20px;padding:20px 14px;}

/* ===== ヘッダー ===== */
.site-header{
  position:sticky;top:0;z-index:40;
  background:#fff;border-bottom:1px solid var(--line);
  max-width:var(--maxw);margin:0 auto;
}
.header-inner{padding:10px 18px;}
.header-logo{width:168px;margin:0 auto;}

/* ============ 1. ファーストビュー（悩み起点） ============ */
.fv{
  background:radial-gradient(120% 70% at 50% 0%, #2d2d2d 0%, var(--black) 72%);
  color:#fff;text-align:center;
  padding:0 18px 30px;overflow:hidden;
}
.fv-flag{
  background:var(--red);color:#fff;
  font-size:13.5px;font-weight:900;letter-spacing:.03em;
  margin:0 -18px 20px;padding:9px 10px;
}
.fv-title{
  font-size:29px;font-weight:900;line-height:1.45;
  margin-bottom:10px;
}
.fv-hl{
  background:linear-gradient(transparent 60%, var(--red) 60%);
  padding:0 4px;
}
.fv-sub{
  font-size:17px;font-weight:700;line-height:1.6;color:#f0f0f0;
  margin-bottom:18px;
}
.fv-sub strong{color:var(--yellow);font-weight:900;}
.fv-img{
  border-radius:12px;margin-bottom:16px;
  border:2px solid #3a3a3a;
}
.fv-read{
  font-size:15px;line-height:1.7;color:#dcdcdc;margin-bottom:6px;
}
.fv-read strong{color:#fff;font-weight:900;}
.fv-pr{font-size:11px;color:#8f8f8f;margin-bottom:16px;}

.fv-badges{
  display:flex;justify-content:center;gap:8px;margin-bottom:16px;
}
.badge{
  display:inline-block;padding:7px 18px;border-radius:999px;
  font-weight:900;font-size:15px;
}
.badge-red{background:var(--red);color:#fff;}
.badge-yellow{background:var(--yellow);color:var(--black);}

.fv-price{
  background:#262626;border:1px solid #444;border-radius:12px;
  padding:12px 14px;margin-bottom:18px;
}
.fv-price-row{font-size:18px;font-weight:700;}
.fv-price-num{font-weight:900;}
.fv-price-num .js-price{
  color:var(--yellow);font-size:34px;
}
.fv-price-note{
  font-size:11px;color:#9a9a9a;line-height:1.6;margin-top:4px;
}
.fv-scroll{
  font-size:16px;font-weight:900;color:var(--yellow);
  animation:bob 1.1s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(5px);}}

/* ============ 2. かんたん診断（アンケート） ============ */
.survey{background:var(--gray-bg);}
.survey-lead{
  font-size:14px;text-align:center;color:#555;margin-bottom:20px;
}
.q-card{
  background:#fff;border:2px solid var(--black);border-radius:14px;
  padding:20px 16px;margin-bottom:16px;text-align:center;
  box-shadow:0 3px 0 rgba(0,0,0,.12);
}
.q-card:last-child{margin-bottom:0;}
.q-no{
  display:inline-block;background:var(--red);color:#fff;
  font-weight:900;font-size:17px;padding:3px 22px;border-radius:999px;
  margin-bottom:14px;
}
.q-img{border-radius:10px;margin-bottom:14px;}
.q-text{
  font-size:18px;font-weight:900;line-height:1.55;margin-bottom:16px;
}
.q-choices{display:flex;gap:12px;}
.choice{
  flex:1;font-family:inherit;cursor:pointer;
  font-size:19px;font-weight:900;
  padding:15px 0;border-radius:10px;
  border:2px solid #ccc;background:#fff;color:#666;
  transition:.15s;
}
.choice:active{transform:scale(.97);}
.choice.selected{background:var(--yellow);border-color:var(--black);color:var(--black);}
.choice[data-val="no"].selected{background:#dde7ff;border-color:#3b5bbf;color:#1f3a8a;}
.q-hint{margin-top:12px;font-size:12.5px;font-weight:700;color:#999;}

/* ============ 3. 診断結果 ============ */
.result{
  background:linear-gradient(180deg,#1f1f1f 0%, var(--black) 100%);
  color:#fff;text-align:center;
}
.result-label{
  display:inline-block;border:2px solid var(--yellow);color:var(--yellow);
  font-size:14px;font-weight:900;letter-spacing:.1em;
  padding:4px 20px;border-radius:999px;margin-bottom:14px;
}
.result-title{
  font-size:23px;font-weight:900;line-height:1.5;margin-bottom:18px;
}
.result-body{
  background:#272727;border-radius:12px;padding:18px 16px;
  text-align:left;font-size:15px;
}
.result-body p+p{margin-top:12px;}
.result-body strong{color:var(--yellow);font-weight:900;}
.result-note{
  font-size:12px;color:#9a9a9a;border-top:1px solid #3d3d3d;
  padding-top:12px;margin-top:14px;
}

/* ============ 4. 初回価格オファー ============ */
.offer{background:#fff;text-align:center;}
.offer-box{
  border:3px solid var(--black);border-radius:14px;
  padding:18px 14px;background:#fffdf0;
}
.offer-name{font-size:17px;font-weight:900;}
.offer-price{
  color:var(--red);font-weight:900;line-height:1.05;
  margin:4px 0 10px;
}
.offer-pre{font-size:22px;margin-right:4px;}
.offer-price .js-price{font-size:62px;letter-spacing:-.02em;}
.offer-yen{font-size:26px;}
.offer-spec{
  list-style:none;display:inline-block;text-align:left;
  font-size:14px;border-top:1px dashed #d8d3a8;padding-top:10px;
}
.offer-spec li{position:relative;padding-left:16px;}
.offer-spec li::before{
  content:"";position:absolute;left:0;top:.7em;
  width:7px;height:7px;border-radius:50%;background:var(--red);
}
.offer-addnote{
  font-size:12px;color:#777;line-height:1.7;
  margin:14px 0 18px;text-align:left;
}

/* ============ 5. こんな男性に ============ */
.for-you{background:var(--gray-bg);}
.check-list{
  list-style:none;max-width:380px;margin:0 auto;
}
.check-list li{
  background:#fff;border-radius:10px;
  font-size:15.5px;font-weight:700;
  padding:14px 14px 14px 46px;margin-bottom:10px;position:relative;
  box-shadow:0 2px 5px rgba(0,0,0,.06);
}
.check-list li::before{
  content:"✔";
  position:absolute;left:12px;top:50%;transform:translateY(-50%);
  width:24px;height:24px;border-radius:50%;
  background:var(--green);color:#fff;
  font-size:14px;font-weight:900;
  display:flex;align-items:center;justify-content:center;
}

/* ============ 6. エラ取り注射とは ============ */
.about{background:#fff;}
.about-img{border-radius:10px;margin-bottom:16px;}
.about-body{font-size:15.5px;}
.about-body p+p{margin-top:12px;}
.about-body strong{
  background:linear-gradient(transparent 60%, var(--yellow-mark) 60%);
  font-weight:900;
}
.about-caution{
  font-size:13px;color:#777;background:var(--gray-bg);
  border-radius:8px;padding:12px;margin-top:14px;
}

/* ============ 7. 施術の流れ ============ */
.flow{background:var(--gray-bg);}
.flow-intro{font-size:14px;text-align:center;color:#555;margin-bottom:20px;}
.flow-step{
  background:#fff;border:2px solid var(--black);border-radius:12px;
  padding:16px;margin-bottom:14px;text-align:center;
}
.flow-step:last-child{margin-bottom:0;}
.flow-no{
  display:inline-block;background:var(--black);color:#fff;
  font-size:14px;font-weight:900;padding:3px 18px;border-radius:999px;
  margin-bottom:12px;
}
.flow-img{border-radius:8px;margin-bottom:10px;}
.flow-text{font-size:15.5px;font-weight:900;line-height:1.5;}
.flow-step--text{padding:18px 16px;}

/* ============ 8. 不安解消FAQ ============ */
.faq{background:#fff;}
.faq-item{
  border:1px solid var(--line);border-radius:10px;
  margin-bottom:10px;overflow:hidden;
}
.faq-item summary{
  list-style:none;cursor:pointer;
  font-size:15.5px;font-weight:900;
  padding:15px 44px 15px 16px;position:relative;
  background:#fafafa;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::before{
  content:"Q";
  color:var(--red);font-weight:900;margin-right:8px;
}
.faq-item summary::after{
  content:"＋";
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  font-weight:900;color:#999;
}
.faq-item[open] summary::after{content:"−";}
.faq-item[open] summary{border-bottom:1px solid var(--line);}
.faq-item p{
  font-size:14.5px;padding:14px 16px;color:#444;
}

/* ============ 9. クリニックの安心材料 ============ */
.clinic-merit{background:var(--gray-bg);}
.merit{
  background:#fff;border-radius:12px;
  padding:18px 16px;margin-bottom:14px;text-align:center;
  box-shadow:0 2px 6px rgba(0,0,0,.07);
}
.merit:last-child{margin-bottom:0;}
.merit-img{border-radius:8px;margin-bottom:12px;}
.merit-title{
  font-size:17px;font-weight:900;color:var(--red);
  line-height:1.45;margin-bottom:6px;
}
.merit-body{font-size:14px;}
.merit--text{padding:20px 16px;}

/* ============ クリニック情報 ============ */
.clinic-info{background:#fff;}
.clinic-photo{border-radius:10px;margin-bottom:16px;}
.clinic-table{
  width:100%;border-collapse:collapse;font-size:14.5px;
  border:1px solid var(--line);
}
.clinic-table th,.clinic-table td{
  border-bottom:1px solid var(--line);
  padding:11px 12px;text-align:left;vertical-align:top;
}
.clinic-table tr:last-child th,
.clinic-table tr:last-child td{border-bottom:none;}
.clinic-table th{
  background:var(--gray-bg);font-weight:900;
  width:86px;white-space:nowrap;
}
.clinic-former{font-size:12px;color:#8a8a8a;}
.clinic-note{font-size:12px;color:#777;margin:12px 0 16px;}
.clinic-map{
  position:relative;width:100%;padding-top:62%;
  border-radius:10px;overflow:hidden;
}
.clinic-map iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;
}

/* ============ 予約フォームのご案内 ============ */
.form-guide{background:#fff;text-align:center;}
.form-guide-lead{font-size:15px;font-weight:700;margin-bottom:16px;}
.form-guide-img{border-radius:10px;}

/* ============ 最終CTA ============ */
.final-cta{
  background:linear-gradient(180deg,#1f1f1f 0%, var(--black) 100%);
  color:#fff;text-align:center;
}
.final-title{
  font-size:21px;font-weight:900;line-height:1.5;margin-bottom:18px;
}
.final-price{
  background:#fffdf0;color:var(--ink);
  border-radius:12px;padding:14px;margin-bottom:18px;
}
.final-price .offer-price{margin:2px 0 4px;}
.final-price-note{font-size:12px;color:#777;}
.final-note{
  font-size:12px;color:#9a9a9a;line-height:1.7;margin-top:16px;
}

/* ============ フッター ============ */
.site-footer{
  background:#0d0d0d;color:#bdbdbd;text-align:center;
  padding:32px 18px 36px;
  max-width:var(--maxw);margin:0 auto;
}
.footer-logo{width:178px;margin:0 auto 16px;}
.footer-philosophy{font-size:13.5px;margin-bottom:18px;}
.site-footer .cta-btn{margin-bottom:22px;}
.footer-compliance{
  background:#1c1c1c;border:1px solid #333;border-radius:8px;
  padding:14px;text-align:left;font-size:11.5px;line-height:1.7;
  color:#9a9a9a;margin-bottom:18px;
}
.footer-compliance-title{
  font-size:12.5px;font-weight:900;color:#d4d4d4;margin-bottom:6px;
}
.footer-compliance p+p{margin-top:8px;}
.footer-info{font-size:12.5px;line-height:1.9;margin-bottom:14px;}
.footer-info a{color:#bdbdbd;}
.copyright{font-size:11px;color:#7a7a7a;}

/* ============ 下部固定CTA ============ */
.fixed-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  background:rgba(0,0,0,.86);
  padding:8px 14px;
  max-width:var(--maxw);margin:0 auto;
}
.fixed-cta .cta-btn{
  font-size:17px;padding:14px;box-shadow:0 3px 0 var(--green-dark);
}
body.has-fixed-cta{padding-bottom:82px;}
