/* ============================================================
   メンズヒゲ脱毛 LP — デザイン刷新（フォントサイズは既存CSSを維持）
   ============================================================ */
:root{
  --navy-deep:#070d18;
  --navy:#0f1729;
  --navy-mid:#1a2744;
  --navy-soft:#243352;
  --blue:#3B7DDD;
  --blue-bright:#5B9FEF;
  --blue-deep:#2563EB;
  --blue-pale:#E8F1FC;
  --blue-mist:#F0F5FB;
  --cyan:#38BDF8;
  --accent-hot:#0EA5E9;
  --border:#C5D3E8;
  --border-strong:#94A8C8;
  --surface:#E4EBF4;
  --card:#fff;
  --glow:rgba(56,189,248,.35);
  /* CTAボタンの色（赤系）。ここを変えれば全CTAに反映されます */
  --cta-bg-from:#FF6B6B;
  --cta-bg-to:#DC2626;
  --cta-shadow:#991B1B;
  --cta-glow:rgba(220,38,38,.35);
  --r-xs:8px;
  --r-sm:12px;
  --r-md:18px;
  --r-lg:24px;
  --shadow-sm:0 2px 8px rgba(7,13,24,.06);
  --shadow:0 6px 28px rgba(7,13,24,.09);
  --shadow-lg:0 12px 40px rgba(7,13,24,.14);
  --theme-head-color:#1a2744 !important;
  --theme-bg-color:#1a2744 !important;
  --theme-secondary-color:#1a2744 !important;
}

/* フォントサイズは上書きしない */
.page-hige .appeal-hero,
.page-hige .target-bar,
.page-hige .appeal-points,
.page-hige .section-shell{
  font-size:inherit;
}

/* ---- ページシェル ---- */
body{
  background:
    linear-gradient(180deg,#d8e4f2 0%,var(--surface) 120px,#e8eef6 100%) !important;
}
.page-hige.ranking{
  max-width:480px;
  margin:0 auto;
  padding-bottom:20px;
  position:relative;
}
.page-hige.ranking::before{
  content:'';
  position:fixed;inset:0;
  max-width:480px;margin:0 auto;
  background-image:
    radial-gradient(circle at 15% 5%,rgba(56,189,248,.12) 0%,transparent 35%),
    radial-gradient(circle at 85% 12%,rgba(59,125,221,.1) 0%,transparent 32%);
  pointer-events:none;z-index:0;
}
.page-hige > *{position:relative;z-index:1}

/* 非表示 */
.ver2-fv-extra{display:none!important}

/* ---- FV ---- */
.page-hige .fv-shell{
  position:relative;
  background:var(--navy-deep);
  overflow:hidden;
}
.page-hige .fv-shell::after{
  content:'';
  position:absolute;left:0;right:0;bottom:0;height:48px;
  background:linear-gradient(transparent,var(--surface));
  pointer-events:none;
}
.page-hige .ranking__head-img{
  display:block;width:100%;
  filter:contrast(1.02) saturate(1.05);
}
.page-hige .ranking__sub-title--fv{
  top:10px!important;right:12px!important;
  background:rgba(7,13,24,.72)!important;
  color:#fff!important;
  border-radius:999px!important;
  padding:4px 10px!important;
  border:1px solid rgba(255,255,255,.2)!important;
  letter-spacing:.06em;
  backdrop-filter:blur(6px);
}

/* ---- 訴求ヒーロー ---- */
.appeal-hero{
  margin:-28px 14px 0;
  padding:14px 16px 16px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 55%,#1e3a5f 100%);
  border-radius:var(--r-md);
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(91,159,239,.25);
  text-align:center;
  position:relative;z-index:6;
  overflow:hidden;
}
.appeal-hero::before{
  content:'';
  position:absolute;top:-40%;right:-20%;
  width:60%;height:120%;
  background:radial-gradient(circle,rgba(56,189,248,.2) 0%,transparent 70%);
  pointer-events:none;
}
.appeal-hero__eyebrow{
  display:inline-block;
  padding:3px 12px;
  background:rgba(56,189,248,.2);
  border:1px solid rgba(56,189,248,.45);
  border-radius:999px;
  color:var(--cyan);
  font-weight:800;
  letter-spacing:.08em;
  margin-bottom:8px;
}
.appeal-hero__title{
  color:#fff;
  font-weight:900;
  line-height:1.45;
  letter-spacing:-.02em;
  text-shadow:0 2px 12px rgba(0,0,0,.25);
}
.appeal-hero__title em{
  color:var(--cyan);
  font-style:normal;
  text-decoration:underline;
  text-decoration-color:rgba(56,189,248,.5);
  text-underline-offset:3px;
}

/* ---- ターゲットバー（訴求強化） ---- */
.target-bar{
  margin:12px 14px;
  padding:0;
  background:var(--card);
  border-radius:var(--r-md);
  box-shadow:var(--shadow);
  border:2px solid var(--border-strong);
  overflow:hidden;
}
.target-bar::before{
  content:'';
  display:block;height:4px;
  background:linear-gradient(90deg,var(--cyan),var(--blue-bright),var(--blue-deep));
}
.target-bar__head{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px 8px;
  background:linear-gradient(90deg,var(--blue-pale) 0%,#fff 100%);
  border-bottom:1px dashed var(--border);
}
.target-bar__badge{
  flex-shrink:0;
  padding:4px 10px;
  background:linear-gradient(135deg,var(--accent-hot),var(--blue-deep));
  color:#fff;
  font-weight:900;
  border-radius:6px;
  letter-spacing:.1em;
  box-shadow:0 2px 8px rgba(37,99,235,.4);
  animation:appeal-pulse 2s ease-in-out infinite;
}
@keyframes appeal-pulse{
  0%,100%{box-shadow:0 2px 8px rgba(37,99,235,.4)}
  50%{box-shadow:0 2px 16px var(--glow)}
}
.target-lead{
  margin:0;
  color:var(--navy);
  font-weight:900;
  line-height:1.4;
  letter-spacing:-.02em;
}
.target-lead em{
  color:var(--blue-deep);
  font-style:normal;
  background:linear-gradient(transparent 65%,rgba(56,189,248,.35) 65%);
}
.target-tags{
  display:flex;flex-wrap:wrap;gap:6px;
  padding:10px 14px;
}
.target-tags span{
  padding:5px 12px;
  border-radius:999px;
  font-weight:800;
  color:var(--navy-mid);
  background:var(--blue-mist);
  border:1px solid var(--border);
}
.target-tags .tag-hot{
  background:linear-gradient(135deg,var(--navy-mid),var(--blue-deep));
  color:#fff;
  border-color:transparent;
  box-shadow:0 2px 10px rgba(37,99,235,.35);
}
.appeal-points{
  list-style:none;
  margin:0;padding:0 14px 14px;
  display:grid;gap:6px;
}
.appeal-points__item{
  position:relative;
  padding:8px 12px 8px 32px;
  background:var(--blue-mist);
  border-left:3px solid var(--blue);
  border-radius:0 var(--r-xs) var(--r-xs) 0;
  font-weight:700;
  color:var(--navy);
  line-height:1.45;
}
.appeal-points__item::before{
  content:'✓';
  position:absolute;left:10px;top:50%;
  transform:translateY(-50%);
  width:18px;height:18px;
  display:flex;align-items:center;justify-content:center;
  background:var(--blue);
  color:#fff;
  border-radius:50%;
  font-weight:900;
  line-height:1;
}

/* ---- セクションシェル ---- */
.section-shell{
  margin:0 14px 32px;
}
.section-shell--compare{
  padding:12px;
  background:var(--card);
  border-radius:var(--r-md);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.section-shell--compare .ranking-compare__title{
  display:block;width:100%;
  border-radius:var(--r-sm);
}
.section-shell--tabs{
  background:var(--card);
  border-radius:var(--r-md);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  overflow:hidden;
  padding-bottom:4px;
}

/* ---- タブ ---- */
.page-hige .tabs{
  display:none;
  gap:8px!important;
  margin:0!important;
  padding:12px!important;
  background:var(--blue-mist)!important;
  border:none!important;
  box-shadow:none!important;
}
.page-hige .tabs .tabs__item{
  flex:1!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  padding:10px 8px!important;
  border-radius:999px!important;
  border:2px solid var(--border)!important;
  background:var(--card)!important;
  color:var(--navy-mid)!important;
  font-weight:800!important;
  transition:transform .15s,box-shadow .15s,background .15s;
}
.page-hige .tabs .tabs__item img{
  filter:opacity(.7);
  width:18px;height:auto;
}
.page-hige .tabs .tabs__item.active,
.page-hige .tabs__item-1.active{
  background:linear-gradient(135deg,var(--navy-mid),var(--blue-deep))!important;
  color:#fff!important;
  border-color:transparent!important;
  box-shadow:0 4px 14px rgba(37,99,235,.35)!important;
  transform:translateY(-1px);
}
.page-hige .tabs .tabs__item.active img{filter:brightness(2)}

/* ---- 比較表 ---- */
.page-hige .ranking-compare__wrapper{
  margin:0 12px 12px!important;
  border-radius:var(--r-sm)!important;
  border:1px solid var(--border)!important;
  background:#fff;
}
.page-hige .ranking-compare__th{
  background:linear-gradient(180deg,var(--navy-mid),var(--navy))!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.1)!important;
}
.page-hige .ranking-compare__td{
  background:#fff;
  border-color:var(--border)!important;
  vertical-align:top;
}
.page-hige .ranking-compare__td-head{
  padding:8px 4px;
}
.page-hige .ranking-compare tbody tr:nth-child(even) .ranking-compare__td{
  background:var(--blue-mist);
}
.page-hige .ranking-compare__badge{
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.15));
}
.page-hige .button-jump.button-jump--small,
.page-hige .ranking-compare a.button-jump{
  border-radius:999px!important;
  background:linear-gradient(135deg,var(--cta-bg-from),var(--cta-bg-to))!important;
  box-shadow:0 4px 0 var(--cta-shadow),0 6px 16px var(--cta-glow)!important;
  border:none!important;
}

/* ---- ランキング見出し画像 ---- */
.page-hige .ranking__title{
  margin:16px 14px 8px!important;
  padding:8px;
  background:var(--card);
  border-radius:var(--r-md);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}

/* ---- クリニックカード ---- */
.page-hige .ranking-item__head,
.page-hige .ranking-item__head-2{
  width:calc(100% - 28px)!important;
  margin:12px 14px 0!important;
  padding-left:72px!important;
  border-radius:var(--r-md) var(--r-md) 0 0!important;
  background:linear-gradient(120deg,var(--navy-mid) 0%,var(--navy-soft) 50%,var(--blue-deep) 100%)!important;
  border:2px solid var(--border-strong)!important;
  border-bottom:none!important;
  box-shadow:var(--shadow);
}
.page-hige .ranking-item__badge{
  top:50%!important;
  transform:translateY(-50%);
  width:52px!important;
  filter:drop-shadow(0 3px 8px rgba(0,0,0,.25));
}
.page-hige .ranking-item__name{
  color:#fff!important;
  text-shadow:0 1px 6px rgba(0,0,0,.3);
}
.page-hige .ranking-item__type{
  background:rgba(255,255,255,.95)!important;
  color:var(--navy-mid)!important;
  border-radius:999px!important;
  padding:2px 10px!important;
  font-weight:800!important;
}
.page-hige .ranking-item{
  width:calc(100% - 28px)!important;
  margin:0 14px 32px!important;
  padding-top:12px!important;
  border:2px solid var(--border-strong)!important;
  border-top:none!important;
  border-radius:0 0 var(--r-md) var(--r-md)!important;
  box-shadow:var(--shadow)!important;
  background:var(--card)!important;
}
.page-hige .ranking-item__star{
  display:flex!important;
  width:calc(100% - 24px)!important;
  margin:0 auto 8px!important;
  padding:8px 12px!important;
  background:linear-gradient(90deg,var(--blue-pale),#fff)!important;
  border-radius:var(--r-sm)!important;
  border:1px solid var(--border)!important;
  color:var(--blue-deep)!important;
}
.page-hige .ranking-item__star-head{
  border-color:var(--blue)!important;
  color:var(--navy-mid)!important;
  background:#fff;
  border-radius:4px;
}
.page-hige .ranking-item__mainimg{
  border-radius:var(--r-sm);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.page-hige .ranking-item__info{
  border-radius:var(--r-xs);
}
.page-hige .hair-machine-item{
  border:1px dashed var(--border)!important;
  border-radius:var(--r-sm)!important;
  margin:8px 12px 12px!important;
  background:var(--blue-mist)!important;
}

/* 訴求テキスト強調（サイズはそのまま） */
.page-hige .red.b,
.page-hige .line{
  color:var(--blue-deep)!important;
  font-weight:800!important;
}
.page-hige .line{
  background:linear-gradient(transparent 60%,rgba(56,189,248,.4) 60%)!important;
}
.page-hige .line-yellow{
  background:linear-gradient(transparent 60%,rgba(56,189,248,.35) 60%)!important;
  color:inherit!important;
}

/* ---- CTAボタン ---- */
.page-hige .button-jump,
.page-hige .ranking__button-campaign{
  border-radius:999px!important;
  background:linear-gradient(180deg,var(--cta-bg-from) 0%,var(--cta-bg-to) 100%)!important;
  box-shadow:0 5px 0 var(--cta-shadow),0 8px 24px var(--cta-glow)!important;
  border:2px solid rgba(255,255,255,.2)!important;
  letter-spacing:.02em;
  position:relative;
  overflow:hidden;
}
.page-hige .button-jump::before{
  content:'';
  position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
  animation:btn-shine 3s ease-in-out infinite;
}
@keyframes btn-shine{
  0%{left:-100%}
  40%,100%{left:150%}
}
.page-hige .button-detail{
  border-radius:999px!important;
  background:linear-gradient(180deg,#64748b,#475569)!important;
  box-shadow:0 4px 0 #334155!important;
}

/* ---- 検索ボックス ---- */
.page-hige .searchbox{
  width:calc(100% - 28px)!important;
  margin:12px 14px!important;
  border-radius:var(--r-md)!important;
  border:2px solid var(--border-strong)!important;
  box-shadow:var(--shadow)!important;
  overflow:hidden;
  background:var(--card)!important;
}
.page-hige .search_head{
  background:linear-gradient(90deg,var(--navy),var(--navy-mid))!important;
  color:#fff!important;
  padding:10px 14px!important;
  letter-spacing:.04em;
}
.page-hige .search_body{
  background:var(--blue-mist)!important;
}
.page-hige .search_body th{
  background:#fff!important;
  border-radius:4px;
  color:var(--navy-mid)!important;
  font-weight:700;
}
.page-hige .checkbox-toggle{
  background:var(--navy-mid)!important;
  color:#fff!important;
  border-radius:var(--r-sm)!important;
  font-weight:800!important;
  margin:8px 14px!important;
  padding:10px!important;
  text-align:center;
}

/* ---- コラム・カテゴリ ---- */
.page-hige .article-list_head,
.page-hige .category-list__title{
  background:linear-gradient(90deg,var(--navy-mid),var(--blue-deep))!important;
  border-radius:var(--r-md) var(--r-md) 0 0!important;
  padding:10px 14px!important;
}
.page-hige .article-list_list,
.page-hige .category-list{
  border:2px solid var(--border-strong)!important;
  border-radius:0 0 var(--r-md) var(--r-md)!important;
  overflow:hidden;
  margin:0 14px 14px!important;
  box-shadow:var(--shadow-sm);
}
.page-hige .article-list_list_item{
  border:1px solid var(--border)!important;
  border-radius:var(--r-xs);
  margin:4px;
  background:var(--card);
  transition:box-shadow .15s,transform .15s;
}
.page-hige .article-list_list_item:active{
  transform:scale(.98);
  box-shadow:var(--shadow-sm);
}

/* ---- フッター ---- */
.page-hige footer,
.page-hige .footer{
  margin:8px 14px 20px!important;
  padding:24px 16px!important;
  border-radius:var(--r-lg) var(--r-lg) 0 0!important;
  background:linear-gradient(165deg,var(--navy) 0%,var(--navy-deep) 100%)!important;
  border-top:3px solid var(--cyan);
  box-shadow:var(--shadow-lg);
}

/* オレンジ・ピンク系の置換 */
.page-hige [style*="orange"],
.page-hige .orange{
  border-color:var(--blue)!important;
}
.page-hige .tabs .tabs__item{
  border-top:none!important;
  border-left:none!important;
}
