/* =========================================
   MEN'S HAIR REMOVAL — LP
   Monotone Luxury Design  v3.0
   ========================================= */

/* ---------- Variables ---------- */
:root {
  --black:     #0a0a0a;
  --gray-900:  #111111;
  --gray-800:  #1c1c1c;
  --gray-700:  #2c2c2c;
  --gray-600:  #3d3d3d;
  --gray-500:  #555555;
  --gray-400:  #888888;
  --gray-300:  #aaaaaa;
  --gray-200:  #cccccc;
  --gray-100:  #e5e5e5;
  --gray-50:   #f4f4f4;
  --white:     #ffffff;
  --line-green:#e6c200;
  --line-dark: #c9a800;
  --line-text: #1a1a1a;
  --gold:      #b8a87a;
  --gold-lt:   #d4c49a;

  --font-serif:'Noto Serif JP','Georgia',serif;
  --font-sans: 'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;
  --font-en:   'Cormorant Garamond',serif;
  --font-price:'Cormorant Garamond','Georgia',serif;

  --radius-s:  6px;
  --radius-m:  12px;
  --radius-l:  20px;
  --tr:        0.28s ease;
  --sh:        0 4px 28px rgba(0,0,0,0.10);
  --sh-hov:    0 10px 44px rgba(0,0,0,0.18);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  background:var(--gray-50);
  color:var(--gray-800);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  font-size:17px;
}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}

/* ---------- Container ---------- */
.container{
  max-width:1060px;
  margin:0 auto;
  padding:0 24px;
}

/* =========================================
   HEADER
   ========================================= */
.site-header{
  position:sticky;top:0;z-index:100;
  background:var(--black);
  border-bottom:1px solid var(--gray-700);
}
.header-inner{
  max-width:1060px;margin:0 auto;padding:0 24px;
  height:62px;
  display:flex;align-items:center;justify-content:space-between;
}

/* ホームボタン（左上） */
.btn-home-header{
  display:inline-flex;align-items:center;gap:7px;
  color:var(--white);
  background:var(--black);
  border:1px solid rgba(255,255,255,.55);
  padding:9px 18px;border-radius:24px;
  font-size:.82rem;letter-spacing:.08em;
  transition:var(--tr);white-space:nowrap;
  font-family:var(--font-sans);
}
.btn-home-header i{font-size:.9rem;color:var(--white)}
.btn-home-header:hover{background:var(--gray-800);color:var(--white);border-color:var(--white)}

/* =========================================
   HERO / FIRST VIEW
   ========================================= */
.hero{
  position:relative;overflow:hidden;
  background:var(--black);
  padding:100px 24px 90px;
  text-align:center;
}

/* 背景の細いライン装飾 */
.hero-bg-lines{
  position:absolute;inset:0;
  display:flex;justify-content:center;align-items:stretch;
  gap:120px;
  opacity:.06;pointer-events:none;
}
.hero-bg-lines span{
  display:block;width:1px;
  background:linear-gradient(to bottom,transparent,var(--gold),transparent);
}

.hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

.hero-inner{position:relative;z-index:1}

.hero-eyebrow{
  font-family:var(--font-en);
  font-size:.72rem;letter-spacing:.55em;
  color:var(--gold);margin-bottom:22px;
}

.hero-catch{
  font-family:var(--font-serif);
  font-size:clamp(2rem,5.5vw,3.6rem);
  color:var(--white);font-weight:300;
  letter-spacing:.12em;line-height:1.45;
  margin-bottom:24px;
}
.hero-catch em{
  font-style:normal;
  background:linear-gradient(135deg,var(--gold-lt),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-sub{
  font-size:clamp(.88rem,2vw,1rem);
  color:var(--gray-300);letter-spacing:.1em;
  line-height:2.1;margin-bottom:36px;
}

.hero-divider{
  display:flex;align-items:center;justify-content:center;
  gap:16px;margin-bottom:0;
}
.hero-divider span{
  display:block;width:56px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold));
}
.hero-divider span:last-child{
  background:linear-gradient(90deg,var(--gold),transparent);
}
.hero-divider i{color:var(--gold);font-size:.75rem;opacity:.7}

/* =========================================
   MAIN
   ========================================= */
.main-content{padding:0 0 120px}

/* =========================================
   LP SECTION — 共通
   ========================================= */
.lp-section{
  padding:80px 0;
  border-bottom:1px solid var(--gray-100);
}
.lp-section:last-child{border-bottom:none}

/* ダーク背景セクション */
.lp-section--dark{
  background:var(--black);
  border-bottom:1px solid var(--gray-800);
}
.lp-section--dark-mid{
  background:var(--gray-900);
  border-bottom:1px solid var(--gray-800);
}
.lp-section--accent{
  background:var(--gray-800);
  border-bottom:1px solid var(--gray-700);
}

/* セクション見出し */
.sec-label{
  font-family:var(--font-en);
  font-size:.62rem;letter-spacing:.45em;
  color:var(--gold);
  border:1px solid var(--gold);
  padding:4px 14px;display:inline-block;
  margin-bottom:20px;
}
.sec-label--light{
  color:var(--gold);
  border-color:var(--gold);
}

.sec-title{
  font-family:var(--font-serif);
  font-size:clamp(1.2rem,3vw,1.7rem);
  color:var(--gray-900);font-weight:400;
  letter-spacing:.07em;line-height:1.55;
  margin-bottom:28px;
}
.sec-title--white{
  color:var(--white);
}

/* =========================================
   ② 共感セクション
   ========================================= */
.empathy-section{
  background:var(--gray-50);
}
.empathy-list{
  margin-bottom:28px;
}
.empathy-list li{
  font-size:1rem;
  color:var(--gray-700);
  line-height:2;
  padding:10px 0;
  border-bottom:1px solid var(--gray-100);
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.empathy-list li:last-child{border-bottom:none}
.empathy-list li::before{
  content:'';
  display:block;
  width:4px;height:4px;
  border-radius:50%;
  background:var(--gold);
  margin-top:12px;
  flex-shrink:0;
}

.empathy-cta{
  font-size:1rem;
  color:var(--gray-600);
  font-weight:500;
  letter-spacing:.05em;
  padding:20px 0 0;
  border-top:1px solid var(--gray-200);
}
.empathy-cta .arrow-text{
  color:var(--gray-800);
  font-weight:600;
}

/* =========================================
   ③ 停滞理由セクション
   ========================================= */
.stagnation-list{
  margin-bottom:28px;
}
.stagnation-list li{
  font-size:1rem;
  color:var(--gray-300);
  line-height:2;
  padding:10px 0;
  border-bottom:1px solid var(--gray-800);
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.stagnation-list li:last-child{border-bottom:none}
.stagnation-list li::before{
  content:'';
  display:block;
  width:4px;height:4px;
  border-radius:50%;
  background:var(--gold);
  margin-top:12px;
  flex-shrink:0;
}

.stagnation-cta{
  font-size:1rem;
  color:var(--gray-400);
  font-weight:500;
  letter-spacing:.05em;
  padding:20px 0 0;
  border-top:1px solid var(--gray-700);
}
.stagnation-cta .arrow-text{
  color:var(--gray-200);
  font-weight:600;
}

/* =========================================
   ④⑤ 本質・細部セクション
   ========================================= */
.essence-text{
  font-size:clamp(1.1rem,2.5vw,1.4rem);
  font-family:var(--font-serif);
  color:var(--gray-900);
  line-height:1.85;
  font-weight:400;
  letter-spacing:.06em;
  max-width:700px;
}
.essence-text--white{
  color:var(--white);
}

.essence-accent{
  color:var(--gold);
  font-weight:500;
}

/* =========================================
   ⑥ 差別化セクション
   ========================================= */
.diff-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:8px;
}
.diff-card{
  border-radius:var(--radius-m);
  padding:28px 24px;
}
.diff-card--other{
  background:var(--gray-800);
  border:1px solid var(--gray-700);
}
.diff-card--ours{
  background:var(--gray-700);
  border:1px solid var(--gold);
  position:relative;
  overflow:hidden;
}
.diff-card--ours::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.diff-card-head{
  font-family:var(--font-en);
  font-size:.62rem;letter-spacing:.35em;
  margin-bottom:14px;
}
.diff-card--other .diff-card-head{color:var(--gray-500)}
.diff-card--ours .diff-card-head{color:var(--gold)}

.diff-list li{
  font-size:.92rem;
  color:var(--gray-300);
  line-height:1.9;
  padding:6px 0;
  border-bottom:1px solid var(--gray-700);
  display:flex;align-items:flex-start;gap:8px;
}
.diff-card--ours .diff-list li{
  color:var(--white);
  border-bottom-color:var(--gray-600);
}
.diff-list li:last-child{border-bottom:none}
.diff-icon{color:var(--gray-600);font-size:.75rem;margin-top:4px;flex-shrink:0}
.diff-icon--gold{color:var(--gold)}

/* =========================================
   ⑦ 強みセクション
   ========================================= */
.strength-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:8px;
}
.strength-card{
  background:var(--gray-800);
  border:1px solid var(--gray-700);
  border-radius:var(--radius-m);
  padding:28px 22px;
  text-align:center;
  transition:var(--tr);
}
.strength-card:hover{border-color:var(--gold);transform:translateY(-3px)}
.strength-icon{
  width:50px;height:50px;
  background:var(--gray-700);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
}
.strength-icon i{color:var(--gold);font-size:1.1rem}
.strength-title{
  font-family:var(--font-serif);
  font-size:1rem;
  color:var(--white);
  font-weight:400;
  letter-spacing:.05em;
  margin-bottom:10px;
  line-height:1.5;
}
.strength-desc{
  font-size:.85rem;
  color:var(--gray-400);
  line-height:1.85;
  letter-spacing:.03em;
}

/* =========================================
   ⑧ 結果セクション
   ========================================= */
.result-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.result-item{
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-m);
  padding:20px 20px;
  display:flex;
  align-items:flex-start;
  gap:14px;
  box-shadow:var(--sh);
}
.result-item-icon{
  color:var(--gold);
  font-size:1rem;
  margin-top:3px;
  flex-shrink:0;
}
.result-item-text{
  font-size:.92rem;
  color:var(--gray-700);
  line-height:1.85;
  letter-spacing:.04em;
}

/* =========================================
   ⑨ 一撃訴求セクション
   ========================================= */
.punch-section{
  background:var(--black);
  padding:100px 24px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.punch-section::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(184,168,122,.06),transparent);
  pointer-events:none;
}
.punch-section::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.punch-inner{
  position:relative;z-index:1;
  max-width:640px;margin:0 auto;
}
.punch-eyebrow{
  font-family:var(--font-en);
  font-size:.65rem;letter-spacing:.5em;
  color:var(--gold);
  border:1px solid var(--gold);
  padding:5px 18px;display:inline-block;
  margin-bottom:36px;
}
.punch-text{
  font-family:var(--font-serif);
  font-size:clamp(1.1rem,2.8vw,1.5rem);
  color:var(--white);
  font-weight:300;
  line-height:2;
  letter-spacing:.07em;
  margin-bottom:16px;
}
.punch-text .punch-em{
  display:block;
  font-size:clamp(1.25rem,3.5vw,1.85rem);
  color:var(--gold-lt);
  font-weight:400;
  margin:8px 0;
  letter-spacing:.08em;
}
.punch-divider{
  width:60px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:36px auto;
}

/* =========================================
   ⑩ 価値セクション
   ========================================= */
.value-text{
  font-size:1rem;
  color:var(--gray-700);
  line-height:2;
  margin-bottom:24px;
}
.value-point-list{
  margin-top:8px;
}
.value-point-list li{
  font-size:.95rem;
  color:var(--gray-700);
  padding:12px 0;
  border-bottom:1px solid var(--gray-100);
  display:flex;
  align-items:flex-start;
  gap:14px;
  line-height:1.85;
}
.value-point-list li:last-child{border-bottom:none}
.vp-icon{color:var(--gold);font-size:.85rem;margin-top:4px;flex-shrink:0}

/* =========================================
   ⑪ リスクセクション
   ========================================= */
.risk-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.risk-item{
  background:var(--gray-800);
  border:1px solid var(--gray-700);
  border-radius:var(--radius-m);
  padding:20px 20px;
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.risk-item-icon{
  color:var(--gray-500);
  font-size:.9rem;
  margin-top:3px;
  flex-shrink:0;
}
.risk-item-text{
  font-size:.9rem;
  color:var(--gray-400);
  line-height:1.85;
  letter-spacing:.03em;
}

/* =========================================
   ⑫ 未来セクション
   ========================================= */
.future-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.future-item{
  background:var(--gray-800);
  border:1px solid var(--gray-700);
  border-radius:var(--radius-m);
  padding:22px 20px;
  display:flex;
  align-items:flex-start;
  gap:14px;
  transition:var(--tr);
}
.future-item:hover{border-color:var(--gold)}
.future-item-icon{
  color:var(--gold);
  font-size:1rem;
  margin-top:3px;
  flex-shrink:0;
}
.future-item-text{
  font-size:.92rem;
  color:var(--gray-300);
  line-height:1.9;
  letter-spacing:.04em;
}

/* =========================================
   ⑬ 不安セクション
   ========================================= */
.faq-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.faq-item{
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-m);
  overflow:hidden;
  box-shadow:var(--sh);
}
.faq-q{
  padding:20px 24px;
  font-size:.95rem;
  color:var(--gray-900);
  font-weight:500;
  letter-spacing:.04em;
  display:flex;
  align-items:flex-start;
  gap:12px;
}
.faq-q-icon{
  color:var(--gold);
  font-family:var(--font-en);
  font-size:1.1rem;
  font-weight:600;
  flex-shrink:0;
  margin-top:1px;
}
.faq-a{
  padding:0 24px 20px 48px;
  font-size:.9rem;
  color:var(--gray-500);
  line-height:2;
  letter-spacing:.03em;
}

/* =========================================
   ⑭ 判断基準セクション
   ========================================= */
.criteria-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.criteria-item{
  display:flex;
  align-items:center;
  gap:20px;
  background:var(--gray-800);
  border:1px solid var(--gray-700);
  border-radius:var(--radius-m);
  padding:20px 24px;
}
.criteria-num{
  font-family:var(--font-en);
  font-size:2rem;
  font-weight:300;
  color:var(--gray-600);
  line-height:1;
  flex-shrink:0;
  width:40px;
}
.criteria-text{
  font-size:.95rem;
  color:var(--gray-200);
  line-height:1.85;
  letter-spacing:.04em;
}
.criteria-text strong{
  display:block;
  font-size:1.05rem;
  color:var(--white);
  margin-bottom:2px;
  font-weight:500;
}

/* =========================================
   ⑮ 料金セクション
   ========================================= */
.plan-section{margin-bottom:80px}

.plan-section-label{
  display:flex;align-items:center;gap:14px;
  margin-bottom:28px;
}
.ps-num{
  font-family:var(--font-en);
  font-size:2.4rem;font-weight:300;
  color:var(--gray-200);line-height:1;
}
.ps-tag{
  font-family:var(--font-en);
  font-size:.65rem;letter-spacing:.4em;
  color:var(--gold);
  border:1px solid var(--gold);
  padding:4px 14px;
}

.plan-main-card{
  display:grid;
  grid-template-columns:1fr 1fr;
  border-radius:var(--radius-l);
  overflow:hidden;
  box-shadow:var(--sh);
  transition:var(--tr);
}
.plan-main-card:hover{box-shadow:var(--sh-hov);transform:translateY(-3px)}

.no1-card .pmc-left{background:var(--black)}
.no2-card .pmc-left{background:var(--gray-800)}

.pmc-left{
  padding:44px 40px;
  position:relative;
}
.pmc-left::after{
  content:'';
  position:absolute;right:0;top:40px;bottom:40px;width:1px;
  background:linear-gradient(to bottom,transparent,var(--gray-600),transparent);
}

.pmc-badge{
  display:inline-block;
  font-size:.7rem;letter-spacing:.05em;
  background:var(--gray-600);color:var(--white);
  padding:4px 14px;border-radius:20px;
  margin-bottom:18px;
}
.secondary-badge{background:var(--gray-500)}

.pmc-title{
  font-family:var(--font-serif);
  font-size:clamp(1.5rem,3vw,2rem);
  color:var(--white);font-weight:400;
  letter-spacing:.08em;line-height:1.4;
  margin-bottom:12px;
}

.pmc-time{
  font-size:.9rem;color:var(--gray-300);
  letter-spacing:.05em;margin-bottom:28px;
}
.pmc-time i{color:var(--gold);margin-right:6px}

.pmc-parts-label{
  font-family:var(--font-en);
  font-size:.62rem;letter-spacing:.3em;
  color:var(--gold);
  margin-bottom:14px;text-transform:uppercase;
}

.pmc-parts-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:12px;
}
.parts-group{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-s);
  padding:10px 14px;
}
.parts-group-name{
  display:block;
  font-size:.92rem;color:var(--white);
  font-weight:500;letter-spacing:.04em;
  margin-bottom:4px;
}
.parts-group-detail{
  display:block;
  font-size:.82rem;color:var(--gray-400);
  letter-spacing:.03em;line-height:1.6;
}
.vio-group{
  grid-column:1/-1;
  background:rgba(184,168,122,.07);
  border-color:rgba(184,168,122,.2);
}
.vio-group .parts-group-name{color:var(--gold-lt)}

.no1-card .pmc-right{background:var(--gray-50)}
.no2-card .pmc-right{background:var(--white)}

.pmc-right{padding:44px 40px;display:flex;align-items:center}

.price-block-wrap{width:100%}

.price-normal-row{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:18px;
  border-bottom:1px solid var(--gray-200);
  margin-bottom:20px;
}
.pb-label{
  font-size:.88rem;color:var(--gray-500);letter-spacing:.05em;
}
.pb-price{
  font-family:var(--font-price);
  font-size:.95rem;color:var(--gray-500);
  text-decoration:line-through;
}
.pb-price small{font-size:.7em}
.pb-price strong{font-size:1.4rem;font-weight:500}

.price-line-row{
  background:var(--gray-900);
  border-radius:var(--radius-m);
  padding:20px 22px;
  margin-bottom:16px;
}
.price-line-badge{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--line-green);color:var(--line-text);
  font-size:.72rem;padding:5px 14px;border-radius:16px;
  margin-bottom:12px;font-weight:700;
}
.price-line-badge i{font-size:.9rem}
.price-line-arrow{
  font-size:.75rem;color:var(--gray-400);
  letter-spacing:.04em;margin-bottom:6px;
}
.price-line-arrow i{color:var(--gray-500);margin:0 4px}
.price-line-big{
  font-family:var(--font-price);
  color:var(--white);
  font-size:1rem;
}
.price-line-big small{font-size:.75em;color:var(--gray-300)}
.price-line-big strong{
  font-size:3.2rem;font-weight:600;
  letter-spacing:-.01em;
}

.price-note-text{
  font-size:.82rem;color:var(--gray-400);
  letter-spacing:.04em;margin-bottom:20px;
}

.btn-line-card{
  display:flex;align-items:center;justify-content:center;gap:10px;
  width:100%;
  background:var(--line-green);color:var(--line-text);
  padding:15px 20px;border-radius:40px;
  font-size:.95rem;font-weight:700;letter-spacing:.06em;
  box-shadow:0 4px 18px rgba(230,194,0,.25);
  transition:var(--tr);
}
.btn-line-card:hover{background:var(--line-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(230,194,0,.38)}
.btn-line-card i{font-size:1.1rem}

/* =========================================
   WHITENING OPTION セクション
   ========================================= */
.whitening-section{
  margin-bottom:80px;
}
.whitening-card{
  background:var(--black);
  border-radius:var(--radius-l);
  overflow:hidden;
  position:relative;
  box-shadow:0 8px 48px rgba(0,0,0,.22);
  padding:44px 48px;
}
.whitening-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  pointer-events:none;
}
.whitening-card::after{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 110%,rgba(184,168,122,.06),transparent);
  pointer-events:none;
}
.whitening-card-inner{
  position:relative;z-index:1;
}
.whitening-title{
  font-family:var(--font-serif);
  font-size:clamp(1.35rem,3vw,1.85rem);
  color:var(--white);
  font-weight:400;
  letter-spacing:.08em;
  line-height:1.55;
  margin-bottom:20px;
  word-break:keep-all;
}
.whitening-desc{
  font-size:.95rem;
  color:var(--gray-300);
  line-height:2;
  letter-spacing:.05em;
  margin-bottom:28px;
  word-break:keep-all;
}
.whitening-price-row{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--gray-800);
  border:1px solid var(--gray-700);
  border-radius:var(--radius-m);
  padding:12px 22px;
  margin-bottom:28px;
}
.whitening-price-label{
  font-size:.85rem;
  color:var(--gray-400);
  letter-spacing:.06em;
  word-break:keep-all;
  white-space:nowrap;
}
.whitening-price-val{
  font-family:var(--font-price);
  color:var(--white);
  font-size:.9rem;
}
.whitening-price-val strong{
  font-size:2rem;
  font-weight:600;
  letter-spacing:-.01em;
}
.btn-whitening{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--line-green);color:var(--line-text);
  padding:15px 36px;border-radius:40px;
  font-size:.95rem;font-weight:700;letter-spacing:.07em;
  box-shadow:0 4px 22px rgba(230,194,0,.28);
  transition:var(--tr);
  word-break:keep-all;
  white-space:nowrap;
}
.btn-whitening:hover{background:var(--line-dark);transform:translateY(-2px);box-shadow:0 8px 32px rgba(230,194,0,.42)}
.btn-whitening i{font-size:1rem}

@media(max-width:900px){
  .whitening-card{padding:36px 32px}
}
@media(max-width:600px){
  .whitening-section{margin-bottom:64px}
  .whitening-card{padding:28px 20px}
  .whitening-title{font-size:1.15rem;letter-spacing:.05em}
  .whitening-desc{font-size:.9rem}
  .whitening-price-row{padding:10px 16px;gap:8px}
  .whitening-price-label{font-size:.8rem}
  .whitening-price-val strong{font-size:1.7rem}
  .btn-whitening{padding:14px 28px;font-size:.9rem;width:100%;max-width:320px}
}

/* 料金注釈 */
.price-compare-note{
  margin-top:28px;
  padding:18px 24px;
  background:var(--gray-800);
  border:1px solid var(--gray-700);
  border-radius:var(--radius-m);
  font-size:.88rem;
  color:var(--gray-400);
  line-height:1.9;
  letter-spacing:.04em;
}

.section-title-block{margin-bottom:32px}
.section-main-title{
  font-family:var(--font-serif);
  font-size:clamp(1.4rem,3vw,1.9rem);
  color:var(--gray-900);font-weight:400;
  letter-spacing:.08em;margin-bottom:8px;
}
.section-main-sub{
  font-size:.88rem;color:var(--gray-400);letter-spacing:.08em;
}

.popular-parts-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.pp-card{
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-l);
  padding:28px 24px;
  display:flex;flex-direction:column;
  align-items:center;text-align:center;
  gap:16px;
  box-shadow:var(--sh);
  transition:var(--tr);
  position:relative;overflow:hidden;
}
.pp-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gray-700),var(--gray-400));
}
.pp-card:hover{transform:translateY(-4px);box-shadow:var(--sh-hov)}

.pp-icon{
  width:52px;height:52px;border-radius:50%;
  background:var(--gray-900);
  display:flex;align-items:center;justify-content:center;
}
.pp-icon i{font-size:1.2rem;color:var(--gold)}

.pp-body{flex:1}
.pp-name{
  font-family:var(--font-serif);
  font-size:1.1rem;color:var(--gray-900);
  font-weight:400;letter-spacing:.04em;
  margin-bottom:6px;
}
.pp-time{font-size:.82rem;color:var(--gray-400);letter-spacing:.04em}
.pp-time i{color:var(--gray-300);margin-right:4px}

.pp-price{
  font-family:var(--font-price);
  font-size:.9rem;color:var(--gray-500);
}
.pp-price small{font-size:.75em}
.pp-price strong{
  font-size:2.3rem;font-weight:600;
  color:var(--gray-900);display:block;line-height:1.15;
}

.fullbody-card{
  background:var(--black);
  border-radius:var(--radius-l);
  overflow:hidden;
  display:flex;align-items:stretch;
  box-shadow:0 8px 48px rgba(0,0,0,.22);
  position:relative;
}
.fullbody-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 110%,rgba(184,168,122,.07),transparent);
  pointer-events:none;
}
.fullbody-card::after{
  content:'';
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

.fb-left{
  flex:1;padding:52px 48px;
  position:relative;z-index:1;
}
.fb-title{
  font-family:var(--font-serif);
  font-size:clamp(1.6rem,3.5vw,2.4rem);
  color:var(--white);font-weight:300;
  letter-spacing:.1em;line-height:1.4;
  margin-bottom:16px;
}
.fb-title span{
  font-size:.65em;color:var(--gold-lt);
  display:block;margin-top:4px;
  letter-spacing:.15em;
}
.fb-parts{
  font-size:.92rem;color:var(--gray-400);
  letter-spacing:.07em;line-height:1.9;
  margin-bottom:16px;
}
.fb-time{font-size:.9rem;color:var(--gray-300);letter-spacing:.05em}
.fb-time i{color:var(--gold);margin-right:6px}

.fb-center-divider{
  width:1px;
  background:linear-gradient(to bottom,transparent,var(--gray-700),transparent);
  margin:40px 0;flex-shrink:0;
}

.fb-right{
  min-width:260px;flex-shrink:0;
  padding:52px 48px;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;
}

.fb-price-item{
  text-align:center;
}
.fb-price-label{
  display:block;
  font-family:var(--font-en);font-size:.65rem;
  letter-spacing:.4em;color:var(--gray-400);
  margin-bottom:12px;
}
.fb-price-val{
  font-family:var(--font-price);
  font-size:1rem;color:var(--gray-200);
}
.fb-price-val small{font-size:.75em;color:var(--gray-400)}
.fb-price-val strong{
  font-size:3.4rem;font-weight:600;
  color:var(--white);display:block;
  line-height:1.1;letter-spacing:-.01em;
}

/* =========================================
   ⑯ 結論セクション
   ========================================= */
.conclusion-text{
  font-family:var(--font-serif);
  font-size:clamp(1.1rem,2.5vw,1.4rem);
  color:var(--gray-900);
  font-weight:400;
  line-height:2;
  letter-spacing:.06em;
  max-width:700px;
  margin-bottom:20px;
}
.lp-section--dark .conclusion-text{
  color:var(--gray-200);
}
.lp-section--dark .sec-title{
  color:var(--white);
}

/* =========================================
   ⑰⑱ 最終クロージングセクション
   ========================================= */
.closing-section{
  background:var(--black);
  padding:100px 24px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.closing-section::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 50% at 50% 100%,rgba(184,168,122,.08),transparent);
  pointer-events:none;
}
.closing-inner{
  position:relative;z-index:1;
  max-width:600px;margin:0 auto;
}
.closing-lead{
  font-size:clamp(.95rem,2vw,1.1rem);
  color:var(--gray-300);
  line-height:2.1;
  letter-spacing:.06em;
  margin-bottom:40px;
}
.closing-main{
  font-family:var(--font-serif);
  font-size:clamp(1.15rem,3vw,1.6rem);
  color:var(--white);
  font-weight:300;
  line-height:1.9;
  letter-spacing:.08em;
  margin-bottom:20px;
}
.closing-main em{
  font-style:normal;
  background:linear-gradient(135deg,var(--gold-lt),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.closing-sub{
  font-size:clamp(.9rem,1.8vw,1rem);
  color:var(--gray-400);
  line-height:2;
  letter-spacing:.05em;
  margin-bottom:16px;
}
.closing-divider{
  width:60px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:40px auto;
}

/* =========================================
   ⑲ 最終CTA
   ========================================= */
.final-cta-section{
  padding:80px 24px 100px;
  background:var(--gray-50);
  text-align:center;
}
.final-cta-inner{max-width:560px;margin:0 auto}
.final-cta-label{
  font-family:var(--font-en);
  font-size:.62rem;letter-spacing:.45em;
  color:var(--gold);
  border:1px solid var(--gold);
  padding:4px 14px;display:inline-block;
  margin-bottom:24px;
}
.final-cta-title{
  font-family:var(--font-serif);
  font-size:clamp(1.2rem,3vw,1.7rem);
  color:var(--gray-900);font-weight:400;
  letter-spacing:.07em;line-height:1.6;
  margin-bottom:32px;
}
.btn-line-final{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  background:var(--line-green);color:var(--line-text);
  padding:20px 52px;border-radius:50px;
  font-size:1.05rem;font-weight:700;letter-spacing:.08em;
  box-shadow:0 6px 28px rgba(230,194,0,.38);
  transition:var(--tr);
  width:100%;max-width:400px;
}
.btn-line-final:hover{background:var(--line-dark);transform:translateY(-2px);box-shadow:0 12px 40px rgba(230,194,0,.5)}
.btn-line-final i{font-size:1.3rem}

/* =========================================
   LINE CTA（料金セクション内）
   ========================================= */
.line-cta-section{
  margin-top:80px;
  background:var(--white);
  border:1px solid var(--gray-100);
  border-radius:var(--radius-l);
  overflow:hidden;
  box-shadow:var(--sh);
}
.line-cta-inner{
  display:flex;align-items:stretch;
}

.line-cta-left{
  flex:1;padding:52px 56px;
  border-right:none;
}
.lc-eyebrow{
  font-family:var(--font-en);
  font-size:.62rem;letter-spacing:.45em;
  color:var(--gold);
  border:1px solid var(--gold);
  padding:4px 14px;display:inline-block;
  margin-bottom:20px;
}
.lc-title{
  font-family:var(--font-serif);
  font-size:clamp(1.3rem,2.5vw,1.9rem);
  color:var(--gray-900);font-weight:400;
  letter-spacing:.07em;line-height:1.45;
  margin-bottom:14px;
}
.lc-desc{
  font-size:.93rem;color:var(--gray-500);
  line-height:1.95;margin-bottom:24px;
}

.lc-benefit{
  background:var(--gray-900);
  border-radius:var(--radius-m);
  padding:18px 22px;margin-bottom:28px;
  display:flex;flex-direction:column;gap:10px;
}
.lc-benefit-row{
  display:flex;align-items:center;gap:10px;
  flex-wrap:wrap;font-size:.9rem;color:var(--gray-300);
}
.lc-benefit-row i.fa-line{color:var(--line-green);font-size:1.1rem;filter:drop-shadow(0 0 3px rgba(230,194,0,.5))}
.lc-from{text-decoration:line-through;color:var(--gray-500)}
.lc-arrow{color:var(--gray-500);font-size:.65rem}
.lc-to{color:var(--gold-lt);font-size:1rem}
.lc-to strong{font-size:1.5rem;font-weight:600;color:var(--white)}

.btn-line-main{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--line-green);color:var(--line-text);
  padding:15px 36px;border-radius:40px;
  font-size:.95rem;font-weight:700;letter-spacing:.07em;
  box-shadow:0 4px 22px rgba(230,194,0,.28);
  transition:var(--tr);
}
.btn-line-main:hover{background:var(--line-dark);transform:translateY(-2px);box-shadow:0 8px 32px rgba(230,194,0,.42)}
.btn-line-main i{font-size:1.1rem}

.line-cta-right{
  display:none;
}

/* =========================================
   HEADER LINE BTN
   ========================================= */
.btn-line-header{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--line-green);color:var(--line-text);
  padding:9px 18px;border-radius:24px;
  font-size:.8rem;font-weight:700;letter-spacing:.04em;
  transition:var(--tr);white-space:nowrap;
}
.btn-line-header:hover{background:var(--line-dark);transform:translateY(-1px)}

/* =========================================
   FLOAT LINE BTN
   ========================================= */
.float-line-btn{
  position:fixed;bottom:32px;right:28px;z-index:200;
  background:var(--line-green);color:var(--line-text);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:68px;height:68px;border-radius:50%;
  font-size:.62rem;font-weight:700;letter-spacing:.02em;gap:2px;
  box-shadow:0 6px 24px rgba(230,194,0,.45);
  transition:var(--tr);
  animation:pulse 3s ease-in-out infinite;
}
.float-line-btn i{font-size:1.7rem}
.float-line-btn:hover{transform:scale(1.08);box-shadow:0 10px 36px rgba(230,194,0,.6)}

@keyframes pulse{
  0%,100%{box-shadow:0 6px 24px rgba(230,194,0,.45)}
  50%{box-shadow:0 6px 40px rgba(230,194,0,.65)}
}

/* =========================================
   FOOTER
   ========================================= */
.site-footer{
  background:var(--black);
  padding:56px 24px 64px;
  text-align:center;
}
.footer-inner{max-width:600px;margin:0 auto}
.footer-notes p{
  font-size:.73rem;color:var(--gray-600);
  letter-spacing:.04em;line-height:2.1;
}
.footer-notes{margin-bottom:28px}

/* Topボタン */
.btn-scroll-top{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--white);
  border:1px solid rgba(255,255,255,.55);
  padding:12px 36px;border-radius:24px;
  font-size:.9rem;letter-spacing:.1em;
  margin-bottom:26px;
  transition:var(--tr);
  cursor:pointer;
  background:var(--black);
}
.btn-scroll-top:hover{background:var(--gray-800);color:var(--white);border-color:var(--white)}
.btn-scroll-top i{color:var(--white)}

.footer-copy{font-size:.68rem;color:var(--gray-700);letter-spacing:.1em}

/* =========================================
   SCROLL FADE-IN
   ========================================= */
.fade-in{
  opacity:0;transform:translateY(22px);
  transition:opacity .55s ease,transform .55s ease;
}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* =========================================
   RESPONSIVE — Tablet
   ========================================= */
@media(max-width:900px){

  .lp-section{padding:64px 0}

  .diff-grid{grid-template-columns:1fr}
  .strength-grid{grid-template-columns:1fr 1fr}
  .result-list{grid-template-columns:1fr}
  .risk-list{grid-template-columns:1fr}
  .future-list{grid-template-columns:1fr}

  .plan-main-card{grid-template-columns:1fr}
  .pmc-left::after{display:none}
  .pmc-left,.pmc-right{padding:36px 32px}
  .pmc-parts-grid{grid-template-columns:1fr 1fr}

  .fb-left{padding:40px 36px}
  .fb-center-divider{
    width:auto;height:1px;margin:0 36px;
    background:linear-gradient(to right,transparent,var(--gray-700),transparent);
  }
  .fullbody-card{flex-direction:column}
  .fb-right{
    min-width:unset;padding:32px 36px 44px;
    justify-content:flex-start;
  }
  .fb-price-item{text-align:left}

  .line-cta-inner{flex-direction:column}
  .line-cta-left{border-right:none;border-bottom:1px solid var(--gray-100);padding:40px 32px}
  .line-cta-right{width:100%;padding:36px 32px}

  .popular-parts-grid{grid-template-columns:1fr 1fr}
}

/* =========================================
   RESPONSIVE — Mobile
   ========================================= */
@media(max-width:600px){

  .hero{padding:72px 20px 64px}
  .hero-bg-lines span:nth-child(2){display:none}
  .container{padding:0 18px}
  .main-content{padding:0 0 80px}
  .plan-section{margin-bottom:64px}
  .lp-section{padding:52px 0}

  .header-inner{padding:0 16px}

  /* ヘッダーホームボタン（スマホ） */
  .btn-home-header{
    padding:8px 14px;
    font-size:.75rem;
  }

  /* ヒーロー */
  .hero-catch{letter-spacing:.06em;line-height:1.5}
  .hero-sub{font-size:.9rem;letter-spacing:.06em}

  /* 共感・停滞 */
  .empathy-list li,
  .stagnation-list li{font-size:.93rem;line-height:1.9}

  .empathy-cta,.stagnation-cta{font-size:.93rem}

  /* 本質・細部 */
  .essence-text{font-size:1rem;line-height:1.95}

  /* 差別化 */
  .diff-grid{grid-template-columns:1fr;gap:16px}
  .diff-card{padding:22px 18px}

  /* 強み */
  .strength-grid{grid-template-columns:1fr;gap:14px}
  .strength-card{padding:22px 18px}

  /* 結果 */
  .result-list{grid-template-columns:1fr;gap:12px}
  .result-item{padding:16px 16px}

  /* 一撃訴求 */
  .punch-section{padding:72px 20px}
  .punch-text{font-size:.95rem;line-height:2}
  .punch-text .punch-em{font-size:1.15rem}

  /* 価値 */
  .value-point-list li{font-size:.9rem}

  /* リスク */
  .risk-list{grid-template-columns:1fr;gap:12px}
  .risk-item{padding:16px 16px}

  /* 未来 */
  .future-list{grid-template-columns:1fr;gap:12px}

  /* FAQ */
  .faq-q{padding:16px 18px;font-size:.9rem}
  .faq-a{padding:0 18px 16px 40px;font-size:.85rem}

  /* 判断基準 */
  .criteria-item{padding:16px 18px;gap:14px}
  .criteria-num{font-size:1.6rem;width:32px}
  .criteria-text{font-size:.88rem}

  /* 料金 */
  .pmc-parts-grid{grid-template-columns:1fr}
  .pmc-left,.pmc-right{padding:28px 20px}
  .price-line-big strong{font-size:2.3rem}
  .popular-parts-grid{grid-template-columns:1fr}
  .fb-left,.fb-right{padding:32px 20px}
  .fb-right{padding-bottom:36px}

  /* 料金注釈 */
  .price-compare-note{font-size:.82rem;padding:14px 18px}

  /* CTA */
  .line-cta-left{padding:28px 18px}
  .lc-benefit-row{font-size:.78rem}

  /* クロージング */
  .closing-section{padding:72px 20px}
  .closing-main{font-size:1.05rem;letter-spacing:.05em}
  .closing-lead{font-size:.9rem}
  .closing-sub{font-size:.88rem}

  /* 最終CTA */
  .final-cta-section{padding:60px 20px 80px}
  .btn-line-final{padding:18px 32px;font-size:.95rem}

  /* フロートボタン */
  .float-line-btn{bottom:20px;right:16px;width:62px;height:62px}
  .float-line-btn i{font-size:1.5rem}
  .float-line-btn span{font-size:.58rem}

  .ps-num{font-size:1.8rem}
}
