:root {
    --page-width: 1280px;
    --bg: #ffffff;
    --bg-yellow: #FFF7D2;
    --bg-blue: #CEF2FF;
    --bg-red: #FFEBED;
    --bg-gray: #F3F3F3;
    --text-red: #D00F31;
    --dark-red: #CC0033;
    --text-black: #333333;
    --text-blue: #1B67BD;
    --white: #FFFFFF;
    --marker-yellow: #FFF885;
    --marker-yellow-dark: #F6D172;
    --marker-yellow-dark_2: #FABE00;
    --font-normal: 500;
    --font-bold: 700;
    --bg-pink: #FED9EC;
	--bg-green: #D3F0B6;
	
    /* sp用フォントサイズ */
    --sp-11: 2.79cqw;
    --sp-12: 3.04cqw;
    --sp-13: 3.29cqw;
    --sp-14: 3.55cqw;
    --sp-15: 3.8cqw;
    --sp-16: 4.06cqw;
    --sp-17: 4.31cqw;
    --sp-18: 4.56cqw;
    --sp-19: 4.81cqw;
    --sp-20: 5.06cqw;
    --sp-21: 5.31cqw;
    --sp-22: 5.56cqw;
    --sp-23: 5.9cqw;
    --sp-24: 6.06cqw;
    --sp-25: 6.34cqw;
    --sp-26: 6.59cqw;
    --sp-27: 6.85cqw;
    --sp-28: 7.06cqw;
    --sp-29: 7.36cqw;
    --sp-33: 8.36cqw;
}

* {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
}

body {
    font-family: "Noto Sans JP", sans-serif;
    color: var(--text-black);
    background: var(--bg);
    font-weight: var(--font-normal);
    -webkit-font-smoothing: antialiased;
}

a:hover {
    opacity: 0.8;
}
.page-root {
    overflow: hidden;
}

/* ページ幅を固定（1280px基準） */
.container {
    width: var(--page-width);
    max-width: 100%;
    margin: 0 auto;
    padding: 0 var(--container-padding);
    container-type: inline-size;
}

/* common */
.font-bold {
    font-weight: var(--font-bold);
}

.color-red {
    color: var(--text-red);
}

.marker {
    background: linear-gradient(transparent 50%, var(--marker-yellow) 50%);
}

.marker_dark {
    background: linear-gradient(transparent 70%, var(--marker-yellow-dark) 70%);
}

.marker_dark_hurf {
    background: linear-gradient(transparent 50%, var(--marker-yellow-dark) 50%);
}

.marker-gray {
    background: linear-gradient(transparent 0%, var(--bg-gray) 0%);
}

.text-20 {
    font-size: 20px;
}

.text-22 {
    font-size: 22px;
}

.text-24 {
    font-size: 24px;
}

.text-27 {
    font-size: 27px;
}

.text-30 {
    font-size: 30px;
}

.text-37 {
    font-size: 37px !important;
}

.text-50 {
    font-size: 50px !important;
}


.text-center {
    text-align: center;
}

sup {
    font-size: 12px;
    vertical-align: super;
}

.m0 {
    margin: 0 !important;
}

.mt14 {
    margin-top: 14px !important;
}

.mt17 {
    margin-top: 17px !important;
}

.mt25 {
    margin-top: 25px !important;
}

.mt30 {
    margin-top: 30px !important;
}
.ml10{
	margin-left: 10px !important;
}

.kome-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

.kome-note {
  position: relative;
  padding-left: 1.2em;
  font-size: 13px;
  line-height: 1.6;
  color: #333;
  text-align: left;
  font-feature-settings: "palt";
}

.kome-note::before {
  content: "※";
  position: absolute;
  left: 0;
/*  top: 0.2em; */
  line-height: 1.6;
}

.selector {
  font-feature-settings: "palt";
}


@media screen and (min-width: 641px){
  .kome-note {
    max-width: 640px;
    margin: 0 auto;
  }
}
.kome-note01 {
  position: relative;
  padding-left: 1.8em;
  font-size: 13px;
  line-height: 1.6;
  color: #333;
  text-align: left;
  font-feature-settings: "palt";
}

.kome-note01::before {
  content: "※1";
  position: absolute;
  left: 0;
  line-height: 1.6;
}
@media screen and (min-width: 641px){
  .kome-note01 {
    max-width: 650px;
    margin: 0 auto;
  }
}
.kome-note00 {
  position: relative;
  padding-left: 1.8em;
  font-size: 13px;
  line-height: 1.6;
  color: #333;
  text-align: left;
  font-feature-settings: "palt";
}

.kome-note00::before {
  content: "＊";
  position: absolute;
  left: 0;
  line-height: 1.6;
}
@media screen and (min-width: 641px){
  .kome-note00 {
    max-width: 650px;
    margin: 0 auto;
  }
}

/* ▼ 全体を中央寄せする親要素 */
.kome13-area {
    text-align: center;
    width: 100%;
}

/* ▼ wrap 自体は中央に配置し、中身だけ左揃えにする */
.kome13-wrap {
    display: inline-block; /* ←中央寄せになる */
    text-align: left;      /* ←2行のテキストは左寄せ */
}

/* ▼ テキスト本体 */
.kome13-text {
    display: block;          /* 1行ずつ縦に並べる */
    position: relative;
    padding-left: 1.2em;     /* ※の分の余白 */
    font-size: clamp(11px, var(--sp-13), 13px);
}

/* ▼ PCでは固定13px */
@media screen and (min-width: 641px) {
    .kome13-text {
        font-size: 13px;
    }
}

/* ▼ ※を prefix として自動追加 */
.kome13-text::before {
    content: "※";
    position: absolute;
    left: 0;
    top: 0;
}
.faq {
    padding: 60px 0;
    background: #f3f3f3;
}

.faq .faq-title {
    font-size: 32px;
    margin-bottom: 40px;
}

.faq .faq-list {
    max-width: 860px;
    margin: 0 auto 28px;
    display: grid;
    gap: 18px;
}

.faq .faq-item {
    text-decoration: none;
    display: grid;
    grid-template-columns: 56px 1fr 40px;
    align-items: center;
    padding: 12px 20px;
    color: var(--text-black);
    border-radius: 8px;
    background: #fff;
}

.faq .faq-item:hover {
    opacity: 0.8;
}

.faq .faq-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--text-red);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 18px;
}

.faq .faq-copy {
    padding-left: 12px;
    font-size: 15px;
    color: var(--text-black);
}

.faq .faq-link {
    text-align: center;
    color: #777;
    font-size: 18px;
}

.btn-outline-ghost {
    text-decoration: none;
    width: 470px;
    margin: 0 auto;
    position: relative;
    padding: 19px 36px;
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 17px;
    font-weight: var(--font-bold);
    color: var(--text-black);
    background: var(--bg);
    border-radius: 56px;
    border: 3px solid #21140f;
    box-shadow: 0 4.516px 0 0 #818181;
}

.btn-outline-ghost:hover {
    opacity: 0.8;
}

.btn-outline-ghost svg {
    position: absolute;
    right: 20px;
    top: 25%;
    padding: 5px;
    width: 33px;
    height: 33px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background: #818181;
}

.faq-cta .wide {
    display: inline-block;
}

.kome-list li {
    display: table;
}

.kome-list li>span {
    display: table-cell;
}

.kome-list li>.kome {
    width: 25px;
}

.bottom-actions {
    margin-top: 32px;
}

.bottom-actions .btn {
    text-decoration: none;
}

.bottom-actions .btn:hover {
    opacity: 0.8;
}

.bottom-actions .wide {
    width: 470px;
    position: relative;
    display: flex;
    height: 60px;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    font-weight: var(--font-bold);
    font-size: 16px;
    color: var(--white);
    box-sizing: border-box;
    border-radius: 3px;
    background: #3A3A3A;
}

.bottom-actions .wide svg {
    position: absolute;
    right: 20px;
    top: 35%;
}

.bottom-actions .big {
    width: 470px;
    position: relative;
    display: flex;
    height: 70px;
    justify-content: center;
    align-items: center;
    margin: 30px auto 0;
    font-weight: var(--font-bold);
    font-size: 22px;
    color: var(--white);
    box-sizing: border-box;
    border-radius: 56px;
    background: var(--docomo-red, #D00F31);
    box-shadow: 0 4.518px 0 0 #9F001C;
}

.bottom-actions .big svg {
    padding: 5px;
    width: 33px;
    height: 33px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background: var(--bg);
    position: absolute;
    right: 20px;
    top: 25%;
}
.btn-with-caption {
	text-align: center;
	margin-bottom: 20px;
}

.btn-caption {
	font-size: clamp(18px, 2.5vw, 23px);
	color: #333;
	font-weight: 700;
	margin-bottom: 8px;
	letter-spacing: 0.05em;
}

.btn-with-caption .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

/* hero */
.hero figure {
    margin: 0
}

.hero .container {
    width: 100%;
}

.hero img {
    line-height: 0.8;
    height: auto;
    max-width: none;
    width: 100%;
}

.site-header {
    padding: 23px 0;
}

.site-header img {
    width: 130px;
}

/* Quick Links component */
.quick-links {
    padding: 25px 0;
    background: var(--bg-pink);
	margin-top:-10px;
}

.quick-links-row {
    margin: 0 auto;
    max-width: calc((215px * 4) + 5px);
    display: flex;
    background: var(--bg-gray);
}

.ql-item {
    width: 215px;
    text-decoration: none;
    position: relative;
    padding: 12px 18px;
    flex: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    color: var(--text-black);
    box-sizing: border-box;
    border: 1px solid var(--text-black);
    border-right: none;
    background: var(--bg);
}

.ql-item:last-child {
    border-right: 1px solid var(--text-black);
}

.ql-icon {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center
}

.ql-text {
    font-weight: var(--font-bold)
}

.ql-item::after {
    content: "";
    position: absolute;
    right: 8px;
    bottom: 8px;
    width: 0;
    height: 0;
    border-left: 8px solid transparent;
    border-top: 8px solid var(--text-red);
    rotate: 90deg;
}

.quick-links-row .ql-item+.ql-item {
    margin-left: 0
}

/* rec-row */
.recommendations .rec-row {
    padding: 40px 0;
    max-width: 1160px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr; /* 3列→2列 */
    gap: 10px 5px;                 /* 縦 横の間隔 */
    justify-items: center;          /* カードを中央寄せ */
}

.recommendations .rec-row .rec-card {
    width: 100%;          /* 幅を揃える */
    max-width: 520px;     /* 必要なら調整 */
}
/* ★見出し①（カード1・2の前） */
.recommendations .rec-top-head{
  grid-column: 1 / -1;
  text-align: center;
  margin: 10px 0 8px;
}

.recommendations .rec-top-title{
  margin-top: 70px;
  font-weight: 800;
  font-size: 26px;
  line-height: 1.2;
}
@media screen and (max-width: 640px){
.recommendations .rec-top-title{
	font-size: 18px;
	line-height: 1.4;
	margin-bottom: -25px;
	margin-top: 40px;
	}
}
/* 「dポイントもどんどん貯まる！」に黄色下線 */
.recommendations .rec-underline{
  background: linear-gradient(transparent 50%, var(--marker-yellow) 50%);
  padding: 0 2px;
}

.tight-txt{font-feature-settings: "palt";}

/* ★見出し②（画像｜テキスト2行｜画像） */
.recommendations .rec-pyramid-head{
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
/*  gap: 24px;*/
  margin: 24px 0 -5px;
  font-weight: 800;

}

.recommendations .rec-poinko{
  width: 100px;
  height: auto;
  flex: 0 0 auto;
}

.recommendations .rec-pyramid-text{
  text-align: center;
  line-height: 1.1;
  flex: 0 1 auto;
}

/* 「＼さらに！／」 */
.recommendations .rec-pyramid-sub{
  margin: 0;
  font-weight: 800;
  font-size: 22px;
  line-height: 1.5;
}

.recommendations .rec-pyramid-title{
  margin: 0;
  font-weight: 800;
  font-size: 38px;
  line-height: 1.1;
}

/* ★3枚目を下段中央に */
.recommendations .rec-card--bottom{
  grid-column: 1 / -1;
  justify-self: center;
}

@media screen and (max-width: 640px){
  .recommendations .rec-pyramid-head{
/*    gap: 12px;*/
    margin: 18px 0 -20px;
  }

  .recommendations .rec-poinko{
    width: 60px;
  }

  .recommendations .rec-pyramid-sub{
    font-size: 16px;
  }

  .recommendations .rec-pyramid-title{
    font-size: 18px;
    line-height: 1.1;
  }
}


.recommendations .rec-card .rec-comment {
    position: relative;
    padding: 15px;
    background: #fff;
    border-radius: 12px;
    border: 3px solid var(--text-red);
}

.recommendations .rec-card .rec-comment::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 12px;
    padding: 1px;
    pointer-events: none
}

.recommendations .rec-pill {
    display: inline-block;
    background: var(--dark-red);
    color: #fff;
    padding: 4px 16px;
    border-radius: 20px;
    font-weight: var(--font-bold);
    font-size: 10px;
    position: absolute;
    left: 0;
    right: 0;
    max-width: fit-content;
    margin: 0 auto;
    top: -12px
}

.recommendations .rec-body p {
    text-align: center;
    margin: 0;
    line-height: 1.4;
    font-weight: var(--font-bold);
}

.recommendations .rec-body .catch {
    font-size: 23px;
}

.recommendations .rec-body .catch span.font-small {
    font-size: 18px;
}

.recommendations .rec-obj {
    position: absolute;
    bottom: -19px;
    left: 0;
    right: 0;
    width: 20px;
    margin: 0 auto;
}

.recommendations .rec-media {
    flex: 0 0 120px
}

.recommendations .rec-copy h3 {
    font-size: 18px;
    margin: 0 0 8px
}

.recommendations .rec-copy p {
    margin: 0;
    color: var(--text-black);
    opacity: 0.85
}

.recommendations .rec-illust {
    margin-top: 12px;
    gap: 23px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.recommendations .rec-card:nth-of-type(1) .rec-illust img {
    max-width: 110px;
    height: auto;
}

.recommendations .rec-card:nth-of-type(2) .rec-illust img {
    max-width: 80px;
    height: auto;
}

.recommendations .rec-illust img {
    max-width: 90px;
    height: auto;
}


/* Docomo Hikari promo styles */
.promo-hikari {
    padding: 36px 0 56px;
    background: #fff;
}

.promo-hikari .promo-head .promo-title img {
    max-width: 420px;
    display: block;
    margin: 0 auto 8px;
}

/* ▼ SP（デフォルト: 80%） */
.promo-head img[src*="consent.svg"] {
    margin-bottom: -20px;
	margin-top: 10px;
    width: 80%;
    height: auto;
}

/* ▼ PC（641px以上: 200px） */
@media screen and (min-width: 641px) {
    .promo-head img[src*="consent.svg"] {
        width: 300px;
		margin-top: 10px;
    }
}

.promo-hikari .promo-sub {
    text-align: center;
    color: var(--text-red);
    font-weight: 700;
    margin: -35px 0 -50px;
}

.promo-hikari .promo-sub .promo-speed {
    font-size: 34px;
    display: inline-block;
    margin-left: 8px
}

.promo-reasons {
    background: #f7f7f7;
    padding: 18px 0;
    margin: 18px 0 28px
}

.reasons-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 880px;
    margin: 0 auto;
}

.reason {
    text-align: center;
    width: 30%;
}

.reason img {
    max-width: 74px;
    display: block;
    margin: 0 auto 8px
}

.pill {
    display: inline-block;
    border-radius: 28px;
    border: 2px solid var(--text-red);
    padding: 8px 28px;
    color: var(--text-red);
    font-weight: 700;
    margin: 18px auto
}

.price-block {
    margin: 14px 0
}

.price-note {
    color: #666;
    margin-bottom: -24px
}

.price {
    font-size: 40px;
    color: var(--text-red);
    font-weight: 800;
    margin: 0
}

.price .yen {
    font-size: 56px
}

.promo-actions {
    margin-top: 20px;
    display: flex;
    gap: 12px;
    justify-content: center;
    align-items: center
}

.promo-actions .btn {
    padding: 12px 20px
}

/* Number Contracts Section */
.number-contracts {
    padding: 60px 0;
    background: #fff;
}

.nc-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-black);
    margin: 0;
    line-height: 1.4;
}


.recommendations .rec-illust .text {
    margin: 0;
}

.recommendations .rec-illust .text .font-large {
    font-size: 18px;
}

/* Product Pills (after recommendations) */
.product-pills {
    padding: 0 0 50px
}

.product-pills .pill-grid {
    max-width: max-content;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(2, 425px);
    gap: 20px
}

.product-pills .pill {
    width: 425px;
    position: relative;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 28px;
    height: 68px;
    border-radius: 56px;
    background: #fff;
    border: 2px solid var(--text-red);
    box-shadow: 0 3.368px 0 0 var(--text-red);
    text-decoration: none;
    color: var(--text-black);
    -webkit-font-smoothing: antialiased;
}

.product-pills .pill-left {
    display: flex;
    align-items: center;
    gap: 14px;
}

.product-pills .pill-logo {
    font-weight: 800;
    font-size: 20px;
    line-height: 1;
}
@media screen and (max-width: 640px) {
    .product-pills .pill-logo img[src*="logo_dokomodenki.svg"] {
        width: 125px; /* テキスト落ち回避のための調整 */
        height: auto;
    }
}
.product-pills .logo-highlight {
    color: #FFD400;
}

.product-pills .pill-right {
    display: flex;
    align-items: center;
    gap: 10px;
}

.product-pills .pill-cta {
    color: #D00F31;
    font-weight: var(--font-bold);
    font-size: 16px;
}

.product-pills .pill-chevron {
    width: 16px;
    height: 16px;
}

/* Extra Info Section */
.extra-info {
    padding: 48px 0;
    background: linear-gradient(180deg, #fff, #fbfbfd);
}

.extra-inner {
    display: flex;
    gap: 36px;
    align-items: center;
    justify-content: space-between;
    max-width: 1160px;
    margin: 0 auto;
}

.extra-copy {
    flex: 1;
    max-width: 560px;
}

.extra-title {
    font-size: 34px;
    margin: 0 0 12px;
}

.extra-lead {
    color: var(--text-black);
    opacity: 0.9;
    margin-bottom: 20px;
    line-height: 1.7;
}

.extra-actions {
    display: flex;
    gap: 14px;
}

.extra-media {
    flex: 1;
    display: flex;
    justify-content: center;
}

.extra-media img {
    max-width: 100%;
    height: auto;
    border-radius: 12px;
    box-shadow: 0 12px 30px rgba(14, 30, 37, 0.06);
}

/* ---- Extra Info ---- */
.extra-info {
    background: var(--bg-yellow);
}

.extra-info .ei-wrap {
    padding: 0 0 50px 0;
    max-width: 1000px;
    margin: 0 auto;
    border-radius: 6px;
    box-sizing: border-box;
    background: var(--bg);
}

.extra-info .ei-ribbon {
    text-align: center;
    padding: 14px 20px;
    max-width: 1000px;
    margin: 18px auto 22px;
    font-weight: var(--font-bold);
    font-size: 24px;
    color: #fff;
    border-radius: 6px 6px 0 0;
    background: var(--text-red);
}

.extra-info .ei-ribbon .font-small {
    font-size: 19px;
}

.extra-info .ei-text {
    margin: 0 0 18px;
    text-align: center;
    line-height: 1.6;
    font-size: 20px;
    font-weight: var(--font-bold);
    color: var(--text-black);
}

.extra-info .ei-top {
    text-align: center;
    margin-bottom: 12px
}

.extra-info .ei-icon {
    display: flex;
    justify-content: center;
    margin-bottom: 12px
}

.extra-info .ei-title {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 13px;
    font-size: 42px;
    margin: 0 0 8px;
    font-weight: 800
}

.extra-info .ei-em {
    color: var(--text-black)
}

.extra-info .ei-sub {
    color: var(--text-black);
    opacity: 0.85;
    margin-bottom: 10px
}

.extra-info .ei-highlight {
    color: var(--text-red);
    font-weight: 800
}

.extra-info .ei-illustration {
    display: flex;
    justify-content: center;
    margin-bottom: 18px
}

.extra-info .ei-benefits {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
}

.extra-info .benefit-card {
    background: #FFEB77;
    border-radius: 8px;
    padding: 28px 20px;
    display: flex;
    gap: 14px;
    align-items: center;
    width: max-content;
}

.extra-info .b-title {
    font-weight: 800;
    margin: 0 0 6px
}

.extra-info .b-desc {
    margin: 0;
    color: var(--text-black)
}

.extra-info .benefit-plus {
    font-size: 36px;
    color: var(--text-red);
    font-weight: 800
}

.extra-info .ei-tabs {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin: 40px 0 0
}

.extra-info .tab {
    position: relative;
    padding: 18px 0;
    width: 434px;
    background: #818181;
    color: #fff;
    font-size: 16px;
    font-weight: var(--font-bold);
    border-radius: 6px 6px 0 0;
    border: none;
    cursor: pointer
}

.extra-info .tab.active {
    background: #333
}

.extra-info .tab.active::after {
    width: max-content;
    margin: 0 auto;
    content: '▼';
    position: absolute;
    bottom: -19px;
    left: 0;
    right: 0;
    color: var(--text-black);
}

.extra-info .ei-carousel {
    display: flex;
    justify-content: center;
    margin-bottom: 23px;
}

.extra-info .carousel-inner {
    max-width: 1000px;
    width: 100%;
    padding: 28px 0 0;
    border-radius: 0 0 10px 10px;
    border: 2px solid var(--text-black);
    background: var(--bg);
}

.extra-info .carousel-inner .ei-panel {
    border-radius: 0 0 10px 10px;
}

.extra-info .ei-carousel .heading3+.text,
.extra-info .ei-carousel .heading3+.text+.caution {
    margin: 0;
}

.extra-info .ei-carousel .heading3+.text {
    margin-top: 12px;
}

.extra-info .plan-pill {
    background: #fff;
    padding: 12px 18px;
    border-radius: 8px;
    font-weight: 800;
    margin-bottom: 12px
}

.extra-info .plan-box {
    margin-top: 20px;
    gap: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.extra-info .plan-box .line {
    display: flex;
    align-items: center;
    gap: 12px;
}

.extra-info .plan-highlight {
    font-weight: 900;
    color: var(--text-red);
    font-size: 28px
}

.extra-info .plan-highlight .big {
    font-size: 44px;
    display: inline-block;
    margin-right: 6px
}


/* ---- Switch area for extra-info (carousel-like) ---- */
.extra-info .switch-area {
    position: relative;
    padding: 43px 67px;
    width: 100%;
    margin-top: 24px;
    border-radius: 0 0 10px 10px;
}

.extra-info .switch-area.pink {
    background: #FAEBF3;
}

.extra-info .switch-area.green {
    background: #E7F7F0;
}

.extra-info .switch-arrow {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: none;
    background: rgba(0, 0, 0, 0.65);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 18px;
}

.extra-info .switch-arrow.left {
    z-index: 10;
    position: absolute;
    top: 57px;
    left: 67px;
    background: var(--text-black);
}

.extra-info .switch-arrow.right {
    z-index: 10;
    position: absolute;
    top: 57px;
    right: 67px;
    background: var(--text-black);
}

.extra-info .switch-arrow:disabled {
    opacity: 0.36;
    cursor: default;
    filter: grayscale(30%);
}

.extra-info .switch-viewport {
    overflow: hidden;
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    display: block;
    height: 360px;
}

.extra-info .switch-slide {
    width: 100%;
    box-sizing: border-box;
    padding: 12px;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(100%);
    transition: transform .36s cubic-bezier(.22, .9, .32, 1);
    z-index: 0;
}

.extra-info .switch-slide.active {
    transform: translateX(0);
    z-index: 2;
}

.extra-info .switch-slide {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 12px;
    box-sizing: border-box;
}

.extra-info .switch-slide .plan-logo-pill {
    background: #fff;
    padding: 4px 12px;
    border-radius: 4px;
}

.extra-info .switch-note {
    margin-bottom: 6px;
    font-weight: var(--font-bold);
    font-size: 14px;
    color: var(--text-black);
}

.extra-info .switch-slide .note-area {
        max-width: 920px;
        margin-left: auto;
        margin-right: auto;
    }
.note-area .kome {
	font-size: 13px;
}
.note-area .text {
	font-size: 13px;
}


.extra-info .info-card {
    background: #fff;
    border-radius: 8px;
    padding: 24px 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 33px;
    width: 100%;
    max-width: 920px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}

.extra-info .info-left {
    display: flex;
    gap: 12px;
    align-items: center;
}

.extra-info .info-icon {
    width: 56px;
    height: 56px;
}

.extra-info .info-copy .info-text {
    margin: 0;
    line-height: 1.6;
    font-size: 18px;
}

.extra-info .info-right {
    line-height: 1;
    font-weight: var(--font-bold);
    font-size: 20px;
}

.extra-info .info-right .font-large {
    font-size: 60px;
    font-weight: 700;
    line-height: 1;
    display: inline-block;
}

.extra-info .ei-inner {
    max-width: 994px;
    margin: 0 auto;
}

.extra-info .ei-bottom-cautions {
    font-size: 13px;
}

.extra-info.gas-info {
    padding-bottom: 71px;
    background: var(--bg-blue);
}

.extra-info.gas-info .tab {
    width: 210px;
}

.extra-info.gas-info .heading2 {
    position: relative;
    padding: 9px;
    max-width: 1000px;
    margin: 40px auto 0;
    text-align: center;
    font-size: 23px;
    color: var(--white);
    background: #00AFEC;
}

.extra-info.gas-info .heading2::after {
    position: absolute;
    bottom: -16px;
    left: 0;
    right: 0;
    content: '▼';
    color: #00AFEC;
}

.extra-info.gas-info .gas-table {
    width: 100%;
    margin: 16px auto;
    border-collapse: collapse;
    font-size: 14px;
}

.extra-info.gas-info .gas-table thead {
    background: #00AFEC;
}

.extra-info.gas-info .gas-table th {
    padding: 12px 14px;
    color: #ffffff;
    font-weight: var(--font-bold);
    text-align: center;
    border: 1px solid #CCCCCC;
}

.extra-info.gas-info .gas-table td {
    padding: 12px 12px;
    text-align: center;
    font-weight: var(--font-bold);
    font-size: 12px;
    border: 1px solid #CCCCCC;
}

.extra-info.gas-info .gas-table td.bg-white {
    background: var(--bg);
}

.extra-info.gas-info .gas-table td.first {
    background: #B5E9FC;
}

.extra-info.gas-info .gas-table td:last-child {
    font-weight: 700;
    color: var(--text-blue);
}

.extra-info.gas-info .gas-media {
    padding: 60px 67px;
    position: relative;
    margin-top: 65px;
    background: #ECFAFF;
}

.extra-info.gas-info .gas-media .icon {
    position: absolute;
    top: -20px;
    right: 0;
    left: 0;
}

.extra-info.gas-info .gas-denki-media {
    padding: 65px 67px 60px;
    position: relative;
    background: var(--bg);
    border-radius: 0 0 10px 10px;
}

.extra-info.gas-info .gas-denki-media .icon {
    position: absolute;
    top: -20px;
    right: 0;
    left: 0;
}

.extra-info.gas-info .gas-denki-media .row {
    display: flex;
    gap: 11px;
    justify-content: center;
    align-items: center;
}

.gas-media .ei-bottom-cautions2 {
    font-size: var(--sp-13);
}

@media screen and (min-width: 641px){
    .gas-media .ei-bottom-cautions2 {
        font-size: 13px;
    }
}

/* ---- promo-hikari ---- */
.promo-hikari {
    padding: 86px 0;
    background: var(--bg-red);
}

.promo-hikari .container {
    max-width: 1000px;
    margin: 0 auto;
}

.promo-hikari .ei-ribbon {
    font-size: 22px;
}

.promo-hikari .ei-wrap {
    padding-bottom: 24px;
}

.promo-hikari .ei-wrap .row {
    gap: 62px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.promo-hikari .ei-wrap .row .row-reason {
    gap: 13px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.promo-hikari .ei-wrap .row .row-reason:first-child img {
    width: 110px;
}

.promo-hikari .ei-wrap .row .row-reason p {
    font-weight: var(--font-bold);
    font-size: 18px;
}

.promo-hikari .pill {
    margin: 37px 0 10px;
    padding: 5px 74px;
    font-weight: var(--font-bold);
    font-size: 24px;
    background: var(--white);
}

.promo-hikari .conditions {
    text-align: center;
    position: relative;
    width: 384px;
    margin: 0 auto;
}

.promo-hikari .conditions {
    padding: 20px 0;
    text-align: center;
    position: relative;
    width: 384px;
    margin: 0 auto;
    color: var(--text-red);
    border-top: 2px solid var(--text-red);
    border-bottom: 2px solid var(--text-red);
}

.promo-hikari .conditions .text {
    font-size: 15px;
    font-weight: var(--font-bold);
}

.promo-hikari .conditions .icon {
    position: absolute;
    right: 0;
    top: 38%;
}

/* ---- promo-home5g ---- */
.promo-home5g {
    padding: 86px 0;
    background: var(--bg);
}

.promo-home5g .container {
    max-width: 1000px;
    margin: 0 auto;
}

.promo-home5g .ei-ribbon {
    font-size: 22px;
}

.promo-home5g .ei-wrap {
    padding-bottom: 24px;
}

.promo-home5g .ei-wrap .row {
    gap: 62px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.promo-home5g .ei-wrap .row .row-reason {
    gap: 13px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.promo-home5g .ei-wrap .row .row-reason p {
    font-weight: var(--font-bold);
    font-size: 18px;
}

.promo-home5g .pill {
    margin: 37px 0 10px;
    padding: 5px 74px;
    font-weight: var(--font-bold);
    font-size: 24px;
    background: var(--white);
}

.promo-home5g .conditions {
    text-align: center;
    position: relative;
    width: 384px;
    margin: 0 auto;
}

.promo-home5g .conditions {
    padding: 20px 0;
    text-align: center;
    position: relative;
    width: 384px;
    margin: 0 auto;
    color: var(--text-red);
    border-top: 2px solid var(--text-red);
    border-bottom: 2px solid var(--text-red);
    margin-top: 30px;}

.promo-home5g .conditions .text {
    font-size: 15px;
    font-weight: var(--font-bold);
}

.promo-home5g .conditions .icon {
    position: absolute;
    right: 0;
    top: 38%;
}

.promo-home5g .promo-sub {
    line-height: 1.3;
    font-weight: var(--font-bold);
    font-size: 42px;
}

.promo-home5g .ei-ribbon {
    margin-top: 0;
}

.promo-home5g .ei-wrap {
    margin-top: 32px;
    border-radius: 12px 12px 8px 8px;
    border: 4px solid var(--text-red);
}

.promo-home5g .row-features {
    gap: 45px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.promo-home5g .row-features .feature-item {
    width: 185px;
    aspect-ratio: 1 / 1;
	display: flex;
    justify-content: center;
    align-self: center;
    flex-direction: column;
    gap: 10px;
    border-radius: 50%;
    background: var(--bg-red);
}

.promo-home5g .row-features .feature-item img {
    margin: 0 auto;
}

.promo-home5g .row-features .feature-item .feature-text {
    line-height: 1.4;
    font-size: 17px;
    font-weight: var(--font-bold);
}

.promo-home5g .price-block {
    margin: 0;
}

.number-contracts {
    background: var(--bg-yellow);
}
.number-contracts .nc-desc {
    text-align: center;
    margin-top: 30px;
    line-height: 1.6;
    font-size: 17px;
    font-weight: var(--font-bold);
}

.number-contracts .nc-inner {
    max-width: 846px;
    margin: 0 auto;
}

.number-contracts .kome-list {
    font-size: 12px;
}

.site-footer {
    padding: 21px 0 88px;
    font-size: 14px;
    font-weight: var(--font-normal);
}
.number-contracts .nc-header {
    text-align: center;
	font-feature-settings: "palt";
    }	

@media (min-width: 901px) {
    .number-contracts .nc-header .nc-title.is-Pc {
        margin: 0 auto;
        /* width: max-content; を削除 */
        display: inline-block;  /* block から inline-block に変更 */
        text-align: center;
    }

    .is-Pc {
        display: inline;
    }

    .is-Sp {
        display: none;
    }
}
	/*accordion*/
	.accordion {
		max-width: 700px;
		margin: 0 auto 10px; /* ★ コンテンツ中央寄せ */
		border-top: 2px solid #D00F31;     /* 上線 */
		border-bottom: 2px solid #D00F31;  /* 下線 */
	}

	/* --- summary（タイトル）--- */
	.accordion summary {
		display: flex;
		justify-content: center; /* ★ タイトル中央 */
		align-items: center;
		position: relative;
		padding: 1.2em 2em;
		color: #D00F31;          /* ★ 色変更 */
		font-weight: 600;
		cursor: pointer;
		text-align: center;
	}

	.accordion summary::-webkit-details-marker {
		display: none;
	}

	.accordion summary::before,
	.accordion summary::after {
		width: 3px;
		height: .9em;
		border-radius: 5px;
		background-color: #D00F31; /* ★ 色変更 */
		content: '';
		position: absolute;
		right: 1.5em;
	}

	.accordion summary::before {
		rotate: 90deg;
	}

	.accordion summary::after {
		transition: rotate .3s;
	}

	.accordion[open] summary::after {
		rotate: 90deg;
	}

	/* --- 本文 --- */
	.accordion p {
		transform: translateY(-10px);
		opacity: 0;
		margin: 0;
		padding: .5em 2em 1.5em;
		color: #333;
		line-height: 1.6;
		text-align: left;        /* ★ 本文は左揃え */
		transition: transform .5s, opacity .5s;
	}

	.accordion[open] p {
		transform: none;
		opacity: 1;
	}

/* --------------------------------------------------
   Responsive: Consolidated media queries (mobile)
   Merged into single block as requested and set to
   max-width: 767px.
   -------------------------------------------------- */
@media (max-width: 900px) {

    /* Container */
    .container {
        width: 100%;
        padding: 0 18px;
    }

    sup {
        font-size: 10px;
    }

    .site-header {
        padding: 12px 0;
    }

    .site-header img {
        width: 102px;
    }

    .media-placeholder {
        width: 320px;
        height: 220px;
    }

    .bottom-actions .wide {
        width: 100%;
    }

    .bottom-actions .wide .text {
        font-size: var(--sp-16);
    }

    .bottom-actions .big {
        width: 100%;
    }

    .bottom-actions .big .text {
        font-size: var(--sp-17);
    }

    .bottom-actions .big svg {
        padding: 8px;
    }

    /* Hero */
    .hero .container {
        padding: 0;
    }

    .hero img {
        width: 100%;
    }

    /* recomendations */
    .recommendations .rec-body p {
        font-size: var(--sp-15);
    }

    .recommendations .rec-body .catch {
        font-size: var(--sp-23);
    }

    .recommendations .rec-body .font-small {
        font-size: var(--sp-19);
    }

    .recommendations .rec-illust .text {
        font-size: var(--sp-15);
    }

    .recommendations .rec-illust .text .font-large {
        font-size: var(--sp-19);
    }

    /* extra-info */
    .extra-info .ei-icon img {
        width: calc(( 79 / 750 ) * 100%);
    }
    
    .extra-info .ei-title {
        font-size: var(--sp-33);
    }
    
    .extra-info .ei-title img {
        width: calc((414 / 750) * 100%);
    }

    .quick-links-row {
        flex-wrap: wrap;
    }

    .quick-links-row .ql-item {
        flex: 1 1 50%;
        border-right: 1px solid var(--text-black);
    }

    .quick-links-row .ql-item:nth-child(n + 3) {
        margin-top: -1px;
    }

    .product-pills .pill-cta {
        font-size: 4cqw;
    }

    .quick-links-row .ql-item:nth-child(even) {
        margin-left: -1px;
    }


    .extra-info .info-right {
        font-size: var(--sp-21);
    }

    /* Pills grid / product pills */
    .pill-grid {
        grid-template-columns: 1fr;
    }

    .pill {
        padding: 12px 16px;
    }

    /* Recommendations -> stack */
    .recommendations .rec-row {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 24px;
    }

    .recommendations .rec-card {
        width: 100%;
    }

    /* extra-info */
    .extra-info {
        padding: 35px 0 70px;
    }

    .extra-info .ei-sub {
        margin-top: 24px;
        line-height: 1.4;
        font-size: var(--sp-17);
    }

    .extra-info .ei-sub .text-27 {
        font-size: var(--sp-21);
    }

    .extra-info .ei-ribbon {
        line-height: 1.4;
        margin-bottom: 0;
        font-size: var(--sp-24);
    }

    .extra-info .ei-ribbon .font-small {
        font-size: var(--sp-19);
    }

    .extra-info .ei-text {
        margin-top: 24px;
        font-size: var(--sp-17);
    }

    .extra-info .ei-wrap {
        padding-bottom: 35px;
    }

    .extra-info .benefit-card {
        width: 90%;
        justify-content: space-between;
    }

    .extra-info .benefit-card .b-icon {
        width: calc(( 134 / 600 ) * 100%);
    }
    
    .extra-info .benefit-card .b-copy {
        font-size: var(--sp-16);
    }
    
    .extra-info .benefit-card .b-copy .text-20 {
        font-size: var(--sp-20);
    }

    .extra-info .tab {
        text-align: left;
        padding: 12px 16px;
        line-height: 1.4;
        font-size: var(--sp-16);
    }

    .extra-info .carousel-inner {
        padding: 24px 0 0;
    }

    .extra-info .heading3.text-27 {
        font-size: var(--sp-24);
    }

    .extra-info .heading3.text-30 {
        font-size: var(--sp-28);
    }
    
    .extra-info .ei-carousel .heading3 + .text {
        font-size: var(--sp-17);
    }

    .extra-info .ei-carousel .heading3 + .text + .caution {
        font-size: var(--sp-13);
        margin-top: 12px;
    }

    .extra-info .plan-box {
        padding: 0 24px;
        flex-direction: column;
        gap: 8px;
        align-items: flex-start;
    }

    .extra-info .plan-box .line img {
        width: 23px;
        display: block;
    }

    .extra-info .plan-box .line .text {
        font-size: var(--sp-22);
    }

    .extra-info .switch-area {
        padding: 14px;
        width: 100%;
    }

    .extra-info .switch-arrow {
        width: 29px;
        height: 29px;
        font-size: 11px;
        display: flex;
        justify-content: center;
        align-self: center;
    }

    .extra-info .switch-arrow.left {
        top: 56px;
        left: 14px;
        width: 29px;
        height: 29px;
    }

    .extra-info .switch-arrow.right {
        top: 56px;
        right: 14px;
        width: 29px;
        height: 29px;
    }

    .extra-info .switch-slide .plan-logo-pill {
        max-width: max-content;
        padding: 20px 35px 12px;
    }

    .extra-info .switch-slide .plan-logo-pill img {
        width: 160px;
    }
    .extra-info .switch-note {
        font-size: var(--sp-14);
    }
	
	.note-area .kome {
	font-size: 12px;
	}
	.note-area .text {
	font-size: 12px;
	}
	
	

    .extra-info .info-copy .info-text {
        font-size: var(--sp-16);
    }

    .extra-info .info-right {
        margin-top: 12px;
        text-align: center;
    }

    .extra-info .switch-viewport {
        height: 590px;
    }

    .extra-info .info-right .font-large {
        font-size: 14.6cqw;   
    }

    .extra-info .info-card {
        padding:  24px 12px;
        flex-direction: column;
        gap: 8px;
    }

    .extra-info .ei-bottom-cautions {
        padding: 0 24px;
        font-size: var(--sp-13);
    }

    .extra-info.gas-info .tab {
        padding: 12px;
        text-align: center;
        font-size: var(--sp-16);
    }

    .extra-info .switch-slide {
        padding: 0;
    }

    .extra-info.gas-info .heading2 {
        font-size: var(--sp-22);
    }

    .extra-info.gas-info .gas-table th {
        font-size: var(--sp-11);
    }

    #gpanel-1 .gas-head img {
        width: 320px;
    }

    #gpanel-2 .gas-head img ,
    #gpanel-3 .gas-head img {
        width: 280px;
    }

    .extra-info.gas-info .ei-panel .gas-cta img {
        width: 274px;
    }

    .extra-info.gas-info .ei-panel .info-text {
        font-size: var(--sp-17);
    }

    .extra-info.gas-info .gas-media {
        margin: 30px 0 0;
        padding: 60px 24px;
    }

    .extra-info.gas-info .gas-denki-media {
        padding: 60px 0;
    }

    .extra-info.gas-info .gas-denki-media {
        padding: 60px 0;
    }

    .extra-info.gas-info .gas-denki-media .text-22 {
        font-size: var(--sp-22);
    }

    .extra-info.gas-info .gas-denki-media .text-27 {
        font-size: var(--sp-26);
    }

    .extra-info .ei-benefits {
        flex-direction: column;
        gap: 0;
    }

    .extra-info.gas-info .gas-table td {
        font-size: var(--sp-11);
    }

    .extra-info.gas-info .gas-denki-media .row {
        padding: 0 24px;
    }

    .extra-info.gas-info .gas-denki-media .row img {
        width: 46%;
    }

    .extra-info .tab.active::after {
        bottom: -17px;
    }

    /* Promo wrap adjustments */
    .promo-hikari .promo-head .promo-title img {
        width: 100%;
    }

    .promo-hikari .promo-head .promo-sub {
        margin-top: -35px;
    }

    .promo-hikari .ei-wrap {
/*        margin-top: -35px;*/
        padding-bottom: 0;
    }

    .promo-hikari .ei-wrap .ei-ribbon {
        margin-bottom: 0;
    }

    .promo-hikari .ei-wrap .row {
        padding: 25px;
        gap: 24px;
        align-items: end;
    }

    .promo-hikari .ei-wrap .row .row-reason {
        flex-direction: column;
        height: 100%;
    }

    .promo-hikari .ei-wrap .row .row-reason p {
        text-align: center;
        line-height: 1.4;
        font-size: var(--sp-18);
    }

    .promo-hikari .ei-wrap .row .row-reason:first-child {
        width: 94px;
    }

    .promo-hikari .ei-wrap .row .row-reason:nth-child(2) img {
        width: 62px;
    }

    .promo-hikari .ei-wrap .row .row-reason:last-child img {
        width: 64px;
    }

    .promo-hikari .pill {
        font-size: var(--sp-20);
    }

    .promo-hikari .conditions {
        margin-top: -35px;
		width: 95%;
    }


    .promo-home5g .promo-head .promo-title img {
        width: 214px;
    }

    .promo-home5g .promo-sub {
        font-size: var(--sp-33);
    }

    .promo-home5g .promo-sub .text-37 {
        font-size: var(--sp-28)!important;
    }

    .promo-home5g .promo-sub .text-50 {
        font-size: 9.69cqw!important;
    }

    .promo-home5g .row-features {
        padding: 15px 15px 0;
        flex-wrap: wrap;
        gap: 15px;
    }

    .promo-home5g .row-features .feature-item {
        width: 47%;
        gap: 0;
    }

    .promo-home5g .row-features .feature-item .feature-text {
        margin-top: 12px;
        font-size: var(--sp-16);
    }

    .promo-home5g .promo-cta-area .conditions {
        margin-top: 15px;
		width: 95%;
    }

    .promo-home5g .ei-bottom-cautions {
        padding: 0;
    }

    /* number-contracts */
    .number-contracts .nc-header .nc-title.is-Sp {
        display: inline-block;
    }

    .number-contracts .nc-desc {
        font-size: var(--sp-17);
    }

    /* Product pills grid for small screens */
    .product-pills .pill-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }

    .product-pills .pill {
        width: 100%;
        padding: 12px 20px 12px 22px;
        height: 60px;
        gap: 8px;        
        border-radius: 100px;
    }

    /* .faq */

    .faq {
        padding: 32px 0;
    }

    .faq .faq-title {
        font-size: 8.1cqw;
    }

    .faq .faq-copy {
        font-size: var(--sp-13);
    }

    /* FAQ adjustments */
    .faq .faq-list {
        padding: 0 12px;
    }

    .faq .faq-item {
        grid-template-columns: 35px 1fr 34px;
        padding: 12px;
    }

    .faq .faq-icon {
        width: 35px;
        height: 35px;
    }

    .btn-outline-ghost {
        width: 100%;
        font-size: var(--sp-17);
    }

    .btn-outline-ghost svg {
        padding: 8px;
    }

    .site-footer {
        padding-bottom: 25px;
        font-size: 10px;
    }

    .is-Sp {
        display: inline;
    }

    .is-Pc {
        display: none;
    }
}

@media screen and (min-width: 901px){
.header-inner{
	padding-left:30px;
	}
}