@charset "UTF-8";
/* ============================================================
   しわ取りボトックスLP【B版・フォーム埋め込み】 / mcc-lazer-hr.com/lp-shiwa-b/
   スマホ専用設計（デスクトップは対象外）
   ============================================================ */

:root{
  --black:#0d0d0d;
  --charcoal:#1a1a1a;
  --dark-gray:#2b2b2b;
  --gray:#777777;
  --light-gray:#f4f4f4;
  --white:#ffffff;
  --ink:#262626;
  --accent:#b89b5e;
  --accent-dark:#8f7440;
  --accent-light:#cdb277;
  --danger-bg:#fff7f7;
  --danger-border:#d7a0a0;
  --danger-text:#9a2b2b;

  --font-ja:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --font-en:"Montserrat","Helvetica Neue",Arial,sans-serif;

  --maxw:480px;
  --radius-sm:6px;
  --radius-md:12px;
  --radius-pill:999px;
  --shadow-card:0 10px 28px rgba(0,0,0,.12);
  --shadow-header:0 4px 18px rgba(0,0,0,.10);
  --header-h:60px;
}

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

html,body{
  font-family:var(--font-ja);
  color:var(--ink);
  background:#dcdcdc;
  line-height:1.8;
  -webkit-text-size-adjust:100%;
  overflow-x:hidden;            /* off-canvasドロワー(translateX(100%))の横スクロール抑止 */
}
body{font-size:16px;}

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

/* ===== レイアウト ===== */
main,.site-header,.site-footer,.fixed-cta{
  max-width:var(--maxw);
  margin-left:auto;margin-right:auto;
}
main{background:var(--white);}
.wrap{padding:0 20px;}
section{padding:56px 0;}

/* ===== 共通：見出し ===== */
.section-label{
  font-family:var(--font-en);
  font-size:12px;font-weight:700;letter-spacing:.22em;
  color:var(--accent);text-align:center;margin-bottom:6px;
}
.section-title{
  font-size:25px;font-weight:900;line-height:1.45;
  text-align:center;margin-bottom:26px;
}

/* ===== 共通CTA ===== */
.btn-primary{
  display:block;text-decoration:none;text-align:center;
  font-weight:700;font-size:18px;line-height:1.4;
  color:#fff;
  background:linear-gradient(135deg,var(--accent-light) 0%,var(--accent) 55%,var(--accent-dark) 100%);
  padding:18px 20px;border-radius:var(--radius-pill);
  box-shadow:0 8px 20px rgba(143,116,64,.36);
  letter-spacing:.04em;
  text-shadow:0 1px 2px rgba(0,0,0,.25);
}
.btn-primary:active{transform:translateY(2px);box-shadow:0 4px 12px rgba(143,116,64,.32);}

/* ============ ヘッダー ============ */
.site-header{
  position:fixed;top:0;left:0;right:0;
  width:100%;max-width:var(--maxw);z-index:90;
  background:rgba(255,255,255,.97);
  box-shadow:var(--shadow-header);
}
.header-inner{
  height:var(--header-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
}
.header-logo{width:138px;}
.header-cta{
  margin-left:auto;margin-right:10px;
  text-decoration:none;font-size:13px;font-weight:700;
  color:#fff;background:var(--charcoal);
  padding:9px 16px;border-radius:var(--radius-pill);
}
.site-header.is-scrolled{box-shadow:0 6px 22px rgba(0,0,0,.16);}

/* ハンバーガー */
.hamburger{
  width:38px;height:38px;border:none;background:transparent;
  cursor:pointer;display:flex;flex-direction:column;
  justify-content:center;align-items:center;gap:5px;
}
.hamburger span{
  display:block;width:24px;height:2px;background:var(--charcoal);
  transition:.25s ease;
}
.hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.is-open span:nth-child(2){opacity:0;}
.hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ナビ ドロワー */
.nav-drawer{
  position:fixed;top:0;bottom:0;left:0;right:0;
  margin-inline:auto;width:100%;max-width:var(--maxw);
  background:var(--charcoal);
  padding:calc(var(--header-h) + 24px) 28px 40px;
  display:flex;flex-direction:column;gap:4px;
  transform:translateX(100%);
  transition:transform .3s ease;z-index:85;
  overflow-y:auto;
}
.nav-drawer.is-open{transform:translateX(0);}
.nav-link{
  color:#fff;text-decoration:none;font-size:17px;font-weight:500;
  padding:16px 4px;border-bottom:1px solid #333;
}
.nav-link:active{color:var(--accent-light);}
.nav-cta{
  margin-top:22px;text-decoration:none;text-align:center;
  color:#fff;font-weight:700;
  background:linear-gradient(135deg,var(--accent-light),var(--accent-dark));
  padding:16px;border-radius:var(--radius-pill);
}
.nav-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:80;
}

/* ============ 1. FV ============ */
.fv{
  position:relative;
  margin-top:var(--header-h);
  min-height:calc(100dvh - var(--header-h));
  display:flex;align-items:center;
  background:linear-gradient(180deg,rgba(13,13,13,.55) 0%,rgba(13,13,13,.78) 100%),
    url("../assets/hero-botox.jpg") center/cover no-repeat;
  padding:0;
}
.fv-inner{padding:48px 24px;color:#fff;width:100%;}
.fv-flag{
  display:inline-block;
  font-size:12px;font-weight:700;letter-spacing:.08em;
  color:var(--black);background:var(--accent-light);
  padding:6px 14px;border-radius:var(--radius-sm);margin-bottom:20px;
}
.fv-title{
  font-size:30px;font-weight:900;line-height:1.55;
  text-shadow:0 2px 12px rgba(0,0,0,.5);margin-bottom:16px;
}
.fv-hl{
  background:linear-gradient(transparent 62%,var(--accent) 62%);
  padding:0 4px;
}
.fv-sub{
  font-size:15px;font-weight:500;line-height:1.9;
  color:#ededed;margin-bottom:22px;
}
.fv-pr{font-size:11px;color:#b9b9b9;margin-bottom:18px;}
.fv-cta{max-width:340px;margin-inline:auto;}
.fv-info{
  list-style:none;display:flex;flex-wrap:wrap;justify-content:center;
  margin-bottom:14px;
}
.fv-info li{
  font-size:11.5px;font-weight:700;color:#fff;
  padding:2px 11px;position:relative;
}
.fv-info li+li::before{
  content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:1px;height:11px;background:rgba(255,255,255,.35);
}

/* ============ 2. こんなお悩み（自分ごと化） ============ */
.recommend{
  background:linear-gradient(180deg,var(--charcoal),var(--black));
  color:#fff;
}
.recommend .section-title{color:#fff;}
.recommend-lead{
  font-size:14px;color:#cfcfcf;text-align:center;margin-bottom:22px;
}
.check-list{list-style:none;}
.check-list li{
  background:#262626;border:1px solid #383838;
  border-radius:var(--radius-md);
  font-size:16px;font-weight:500;
  padding:16px 16px 16px 52px;margin-bottom:12px;position:relative;
}
.check-list li::before{
  content:"";
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  width:24px;height:24px;border-radius:50%;
  background:var(--accent);
}
.check-list li::after{
  content:"";
  position:absolute;left:23px;top:calc(50% - 3px);
  width:6px;height:11px;border:solid #fff;border-width:0 2px 2px 0;
  transform:rotate(45deg);
}

/* ============ 3. ボトックスとは ============ */
.about{background:var(--white);}
.about-img{border-radius:var(--radius-md);margin-bottom:20px;}
.about-body{font-size:15.5px;}
.about-note{font-size:12px;color:var(--gray);margin-top:12px;}

/* ============ 4. クリニックの特徴 ============ */
.features{background:var(--light-gray);}
.features-body{font-size:15.5px;}

/* ============ 5. 人気部位 ============ */
.parts{background:var(--white);}
.part-card{
  border:1px solid #e6e3da;border-radius:var(--radius-md);
  overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow-card);
}
.part-img{aspect-ratio:16/10;object-fit:cover;}
.part-body{padding:18px;}
.part-name{
  font-size:20px;font-weight:900;margin-bottom:6px;
  padding-left:14px;border-left:4px solid var(--accent);
}
.part-desc{font-size:14.5px;}

/* ============ 症例紹介 ============ */
.cases{background:var(--light-gray);}
.cases-lead{font-size:14px;text-align:center;color:#555;margin-bottom:22px;}
.case-card{
  background:var(--white);border-radius:var(--radius-md);
  overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow-card);
}
.case-img{display:block;width:100%;}
.case-cap{padding:16px 16px 18px;}
.case-area{
  display:inline-block;font-size:14px;font-weight:700;color:#fff;
  background:var(--charcoal);padding:3px 14px;border-radius:var(--radius-sm);
  margin-bottom:10px;
}
.case-detail{font-size:13.5px;font-weight:500;margin-bottom:8px;}
.case-risk{font-size:12px;color:var(--gray);line-height:1.7;}
.cases-note{font-size:11.5px;color:var(--gray);line-height:1.7;margin-top:6px;}

/* ============ 6. 料金一覧 ============ */
.price{background:var(--white);}
.price-campaign{
  text-align:center;font-size:16px;font-weight:700;
  color:var(--accent-dark);margin-bottom:14px;
}
.price-list{list-style:none;border-top:1px solid #e6e3da;margin-bottom:14px;}
.price-row{
  display:flex;justify-content:space-between;align-items:center;
  gap:12px;padding:15px 6px;border-bottom:1px solid #e6e3da;
}
.price-part{font-size:15.5px;font-weight:700;}
.price-value{text-align:right;white-space:nowrap;}
.price-old{
  display:block;font-size:12px;color:var(--gray);
  text-decoration:line-through;
}
.price-now{font-size:21px;font-weight:900;color:var(--charcoal);}
.price-ask{font-size:14px;font-weight:700;color:var(--accent-dark);}
.price-note{font-size:12px;color:var(--gray);margin-bottom:22px;line-height:1.7;}

/* ============ 7. 詳細情報 ============ */
.treatment{background:var(--light-gray);}
.treatment-list{border-top:2px solid var(--charcoal);}
.treatment-item{
  padding:14px 4px;border-bottom:1px solid #ddd;
}
.treatment-item dt{
  font-size:13px;font-weight:700;color:var(--accent-dark);
  margin-bottom:2px;
}
.treatment-item dd{font-size:15px;}

/* ============ 8. FAQ ============ */
.faq{background:var(--white);}
.faq-item{
  border:1px solid #e6e3da;border-radius:var(--radius-sm);
  margin-bottom:10px;overflow:hidden;
}
.faq-item summary{
  list-style:none;cursor:pointer;position:relative;
  font-size:15.5px;font-weight:700;
  padding:16px 46px 16px 16px;background:#faf9f6;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::before{content:"Q";color:var(--accent-dark);font-weight:900;margin-right:8px;}
.faq-item summary::after{
  content:"";position:absolute;right:18px;top:50%;
  width:9px;height:9px;border-right:2px solid var(--gray);
  border-bottom:2px solid var(--gray);
  transform:translateY(-70%) rotate(45deg);transition:.2s;
}
.faq-item[open] summary::after{transform:translateY(-30%) rotate(-135deg);}
.faq-item[open] summary{border-bottom:1px solid #e6e3da;}
.faq-item p{font-size:14.5px;color:#444;padding:14px 16px;}

/* ============ 9. 副作用・禁忌 ============ */
.caution{background:var(--light-gray);}
.caution-box{
  background:var(--danger-bg);
  border:1px solid var(--danger-border);
  border-radius:var(--radius-md);
  padding:18px 16px;margin-bottom:16px;
}
.caution-box:last-child{margin-bottom:0;}
.caution-head{
  font-size:16px;font-weight:900;color:var(--danger-text);
  margin-bottom:8px;padding-bottom:8px;
  border-bottom:1px dashed var(--danger-border);
}
.caution-box p{font-size:14px;}
.caution-box strong{font-weight:900;}
.caution-list{margin:10px 0 0 1.1em;font-size:14px;}
.caution-list li{margin-bottom:6px;}
.caution-foot{font-size:12.5px;color:var(--gray);margin-top:10px;}

/* ============ 10. クリニック情報 ============ */
.clinic{background:var(--white);}
.clinic-photo{border-radius:var(--radius-md);margin-bottom:18px;}
.clinic-table{
  width:100%;border-collapse:collapse;font-size:14.5px;
  border:1px solid #e6e3da;margin-bottom:16px;
}
.clinic-table th,.clinic-table td{
  border-bottom:1px solid #e6e3da;
  padding: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(--light-gray);font-weight:700;
  width:84px;white-space:nowrap;
}
.clinic-former{font-size:12px;color:var(--gray);}
.clinic-map{
  position:relative;width:100%;padding-top:64%;
  border-radius:var(--radius-md);overflow:hidden;margin-bottom:20px;
}
.clinic-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* ============ 初回限定キャンペーン ============ */
.campaign{
  background:linear-gradient(180deg,var(--charcoal),var(--black));
  color:#fff;text-align:center;
}
.campaign-flag{
  display:inline-block;
  font-size:13px;font-weight:700;letter-spacing:.08em;
  color:var(--black);
  background:linear-gradient(135deg,var(--accent-light),var(--accent));
  padding:7px 20px;border-radius:var(--radius-pill);margin-bottom:14px;
}
.campaign-title{
  font-size:23px;font-weight:900;line-height:1.5;margin-bottom:20px;
}
.campaign-hl{color:var(--accent-light);font-size:1.5em;}
.campaign-card{
  background:#262626;border:1px solid #3a3a3a;
  border-radius:var(--radius-md);
  padding:16px;margin-bottom:12px;
}
.campaign-name{font-size:16px;font-weight:700;margin-bottom:4px;}
.campaign-off{font-size:14px;font-weight:500;color:#cfcfcf;}
.campaign-off strong{
  color:var(--accent-light);font-weight:900;margin-left:4px;
  font-size:1.7em;
}
.campaign-off strong span{font-size:.46em;margin-left:1px;}
.campaign-note{
  font-size:11.5px;color:#9a9a9a;line-height:1.7;margin:14px 0 20px;
}
/* キャンペーン内の料金表（ダーク背景用の配色上書き） */
.campaign .price-list{border-top-color:#3a3a3a;}
.campaign .price-row{border-bottom-color:#3a3a3a;}
.campaign .price-part{color:#fff;}
.campaign .price-old{color:#9a9a9a;}
.campaign .price-now{color:var(--accent-light);}

/* ダークセクション内のCTA・最終CTA */
.recommend .btn-primary{margin-top:24px;}
.final-cta .recommend-lead{margin-bottom:4px;}

/* ============ ボトックスの効果 ============ */
.effects{background:var(--white);}
.effect-item{
  background:var(--light-gray);
  border-left:4px solid var(--accent);
  border-radius:0 var(--radius-md) var(--radius-md) 0;
  padding:16px 18px;margin-bottom:14px;
}
.effect-no{
  font-family:var(--font-en);font-size:12px;font-weight:700;
  color:var(--accent);letter-spacing:.14em;
}
.effect-name{font-size:18px;font-weight:900;margin-bottom:5px;}
.effect-desc{font-size:14px;}

/* ============ 予約フォーム ウィジェット（B版コア） ============ */
.booking-widget{
  background:linear-gradient(180deg,#fafaf7 0%,#fff 100%);
  border-top:1px solid #e6e3da;border-bottom:1px solid #e6e3da;
}
.booking-widget .hl-yellow{
  background:linear-gradient(transparent 58%,var(--accent-light) 58%);
  font-weight:900;
}
.booking-lead{
  font-size:14px;line-height:1.8;text-align:center;color:#444;
  margin-bottom:10px;
}
.booking-lead strong{color:var(--accent-dark);font-weight:700;}
.booking-subnote{
  font-size:12.5px;line-height:1.7;text-align:center;color:var(--accent-dark);
  background:#fff8e9;border:1px dashed var(--accent);
  border-radius:8px;padding:10px 12px;margin-bottom:20px;
}

.booking-form{display:flex;flex-direction:column;gap:18px;}
.bf-loading,.bf-empty{
  font-size:13.5px;color:var(--gray);text-align:center;padding:14px 0;
}
.bf-legend{
  font-size:15px;font-weight:900;margin-bottom:10px;
  padding-left:10px;border-left:3px solid var(--accent);
}
.bf-slots{border:none;padding:0;margin:0;}
.bf-slots-host{display:flex;flex-direction:column;gap:14px;}
.bf-slot-day{
  background:#fff;border:1px solid #e6e3da;border-radius:var(--radius-md);
  padding:12px 12px 14px;
}
.bf-day{
  font-size:14px;font-weight:900;margin-bottom:8px;color:var(--charcoal);
  padding-left:6px;border-left:3px solid var(--accent);
}
.bf-slot-chips{display:flex;flex-wrap:wrap;gap:8px;}
.bf-slot-chip{
  position:relative;cursor:pointer;
  font-size:14px;font-weight:700;color:var(--ink);
  background:#f4f4f3;border:2px solid transparent;border-radius:999px;
  padding:8px 14px;transition:.15s;
}
.bf-slot-chip input{
  position:absolute;opacity:0;pointer-events:none;width:0;height:0;
}
.bf-slot-chip:has(input:checked),
.bf-slot-chip.is-selected{
  background:var(--accent-light);color:var(--black);
  border-color:var(--accent-dark);
  box-shadow:0 2px 6px rgba(143,116,64,.3);
}

.bf-contact{border:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.bf-row{display:flex;flex-direction:column;gap:6px;}
.bf-label{
  font-size:14px;font-weight:700;color:var(--ink);
}
.bf-req{
  display:inline-block;font-size:11px;font-weight:700;
  color:#fff;background:var(--red);padding:1px 8px;border-radius:4px;
  margin-left:4px;vertical-align:middle;
}
.bf-input{
  font-family:inherit;font-size:16px;line-height:1.5;
  padding:12px 14px;border:1.5px solid #d8d5cc;border-radius:8px;
  background:#fff;color:var(--ink);
  -webkit-appearance:none;
}
.bf-input:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(184,155,94,.18);
}
.bf-hint{font-size:11.5px;color:var(--gray);}
.bf-error{
  background:#fff5f5;border:1px solid #f0bdbd;color:#b03030;
  font-size:13px;padding:10px 12px;border-radius:8px;font-weight:700;
}
.bf-submit{
  margin-top:6px;cursor:pointer;border:none;
  font-family:inherit;
}
.bf-submit:disabled{opacity:.6;cursor:not-allowed;}
.bf-note{
  font-size:11.5px;color:var(--gray);text-align:center;line-height:1.7;
}

.bf-success{
  background:#f3fbf3;border:1px solid #cfe6cf;border-radius:var(--radius-md);
  padding:22px 16px;text-align:center;
}
.bf-success-title{
  font-size:20px;font-weight:900;color:#1e7a3c;margin-bottom:12px;
}
.bf-success p{font-size:14.5px;line-height:1.8;margin-bottom:8px;}
.bf-success-slot{
  display:inline-block;background:#fff;border:1px dashed var(--accent);
  padding:8px 14px;border-radius:8px;font-weight:700;color:var(--accent-dark);
  margin:6px 0 10px;
}
.bf-success-note{font-size:12px;color:var(--gray);margin-top:12px;}

/* ============ フッター ============ */
.site-footer{
  background:var(--black);color:#bdbdbd;text-align:center;
  padding:44px 24px 48px;
}
.footer-logo{width:180px;margin:0 auto 18px;}
.footer-philosophy{font-size:13.5px;line-height:1.9;margin-bottom:22px;}
.footer-cta{max-width:320px;margin:0 auto 24px;}
.footer-info{font-size:12.5px;line-height:1.9;margin-bottom:14px;}
.footer-info a{color:#bdbdbd;}
.copyright{
  font-family:var(--font-en);font-size:10.5px;letter-spacing:.06em;
  color:#6f6f6f;
}

/* ============ 下部固定CTA ============ */
.fixed-cta{
  position:fixed;left:0;right:0;bottom:0;
  width:100%;max-width:var(--maxw);z-index:70;
  background:rgba(13,13,13,.9);
  padding:9px 16px;
}
.fixed-cta .btn-primary{font-size:16px;padding:14px;box-shadow:none;}
body{padding-bottom:78px;}

/* ============ スクロール演出 ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
}

/* ============ マニフェスト（働く男を、徹底的に支援する／FV直下）============ */
.manifesto{background:var(--charcoal);color:#fff;}
.manifesto .wrap{text-align:center;}
.manifesto .mf-en{
  font-family:var(--font-en);font-size:12px;font-weight:700;letter-spacing:.28em;
  color:var(--accent-light);margin-bottom:8px;
}
.mf-title{
  font-size:clamp(24px,7vw,34px);font-weight:900;line-height:1.4;
  margin-bottom:18px;letter-spacing:.01em;
}
.mf-lead{
  font-size:14.5px;line-height:2;color:#d8d4cc;font-weight:500;
  text-align:left;margin-bottom:26px;
}
.mf-policies{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;text-align:left;}
.mf-policies li{
  background:rgba(255,255,255,.04);
  border:1px solid #3a3a3a;border-left:3px solid var(--accent);
  border-radius:var(--radius-sm);padding:14px 16px;
}
.mf-no{
  display:inline-block;font-family:var(--font-en);font-size:12px;font-weight:700;
  letter-spacing:.14em;color:var(--accent-light);margin-bottom:6px;
}
.mf-p-title{font-size:17px;font-weight:900;line-height:1.5;margin-bottom:4px;color:#fff;}
.mf-p-desc{font-size:13.5px;line-height:1.75;color:#b8b3a8;}
