/* N-NOSE campaign LP custom styles（旧: new/index.html インライン<style>を外部化） */
    /* 金額ボタン（intro遷移） */
    .lp2-price-btn { display: inline-block; text-decoration: none; color: inherit; cursor: pointer; transition: opacity .2s; }
    .lp2-price-btn::after { content: ""; display: inline-block; width: .32em; height: .32em; margin-left: .35em; border-top: 3px solid #00a0e9; border-right: 3px solid #00a0e9; transform: rotate(45deg); vertical-align: middle; }
    .lp2-price-btn:hover { opacity: .7; }
    /* 受検後サポート 相談ボタン（全幅にせず適度な幅で中央寄せ） */
    .lp2-support-btn { text-align: center; margin-top: 1.4em; }
    .lp2-support-btn a.c-button--e { display: inline-block; width: auto; min-width: 320px; max-width: 90%; padding-left: 3em; padding-right: 3em; }
    /* TOPに戻る追従ボタン */
    .lp2-pagetop { position: fixed; right: 20px; bottom: 90px; z-index: 99; width: 56px; height: 56px; padding: 0; border: none; border-radius: 50%; background: #00a0e9; color: #fff; font-size: 11px; font-weight: bold; line-height: 1; cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,.25); opacity: 0; visibility: hidden; transition: opacity .3s, visibility .3s; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; }
    .lp2-pagetop.is-visible { opacity: 1; visibility: visible; }
    .lp2-pagetop__arrow { display: block; width: 9px; height: 9px; border-top: 2px solid #fff; border-right: 2px solid #fff; transform: rotate(-45deg); margin-top: 3px; }
    @media (max-width: 767px) { .lp2-pagetop { right: 12px; bottom: 78px; width: 48px; height: 48px; } }
    /* パッケージ画像のアスペクト比維持（新パッケージは縦長のため高さ固定を解除） */
    .mainlead-box__pakage--image { height: auto; }
    .service03--illust5 { height: auto; }
    /* 世界初パッケージ: 縦長画像に合わせ下マージン調整（PCのみ） */
    @media (min-width: 768px) { .mainlead-box__pakage { width: 551px; margin: -150px auto -50px; } }
    /* メリット: カードタイトル */
    .merit__list--title { font-size: 2.5rem; color: #fff228; line-height: 1.3; margin-bottom: 10px; }
    /* メリット: がん種特定の注記（小さめ） */
    .lp2-merit-note { font-size: 1.3rem; margin-top: .5em; opacity: .85; }
    /* 申込ボタン上のキャンペーン表記 */
    .lp2-campaign-label { text-align: center; color: #ff6607; font-size: 2.2rem; font-weight: 700; line-height: 1.3; margin: 0 0 8px; }
    @media (max-width: 767px) { .lp2-campaign-label { font-size: min(5vw, 22px); } }
    /* 受検後サポート: 横並びにしない（縦積み） */
    .howtotest-support__info { display: block; }
    .howtotest-support__info dl:first-child::after { display: none; }
    /* afterflow: 既存SPの「詳しく見る」黄色ストリップを抑制（横ボタンに置換のため） */
    .howtotest__afterflow__flow::after { display: none; }
    /* afterflow: 下部も角丸＋下マージン（単独カード化） */
    .howtotest__afterflow { border-radius: 30px; margin: 0 auto 60px; }
    @media (max-width: 767px) { .howtotest__afterflow { border-radius: 1.8774445893rem; margin-bottom: 6.5%; } }
    /* N-NOSE plus 開閉トグル（横ボタン） */
    .lp2-plus-toggle-wrap { text-align: center; margin-top: 40px; }
    .lp2-plus-toggle { display: inline-flex; align-items: center; justify-content: center; gap: .6em; min-width: min(560px, 90%); padding: 18px 32px; border: none; border-radius: 50px; background: #fdd000; color: #00405a; font-size: 2rem; font-weight: 700; line-height: 1.4; cursor: pointer; box-shadow: 0 3px 0 #d9b500; transition: opacity .2s; }
    .lp2-plus-toggle:hover { opacity: .85; }
    .lp2-plus-toggle::after { content: "＋"; font-size: 1.3em; line-height: 1; }
    .lp2-plus-toggle[aria-expanded="true"]::after { content: "−"; }
    /* nnoseplus: 既定は非表示、トグルで開く */
    #nnose-plus { display: block; }
    @media (max-width: 767px) { .lp2-plus-toggle { font-size: min(4.2vw, 20px); padding: 14px 20px; } }
    /* ===== p-flow（n-nose-main-lpより移植・共通styleに統合） ===== */
    :root {
      --font-jp: "Inter", sans-serif; --font-en: "Poppins", sans-serif;
      --c-blue: #00a3e0; --c-text: #333;
      --fs-h2: clamp(1.5rem, 4vw, 2.5rem); --fs-eyebrow: clamp(0.8125rem, 1.4vw, 1rem); --fs-body: clamp(0.9375rem, 1.4vw, 1rem);
      --sp-2: 16px; --sp-4: 32px; --sp-6: 48px; --sp-8: 64px; --gap-card: 24px;
      --container: 1200px; --container-pad: clamp(20px, 6vw, 80px);
    }
    .p-flow .l-container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--container-pad); }
    .p-flow .c-section-head { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--sp-2); margin-bottom: var(--sp-6); }
    .p-flow .c-section-head__title { font-size: 5.2rem; font-weight: 700; line-height: 1.3; letter-spacing: .08em; color: #00a3e0; }
    .p-flow { padding-block: var(--sp-8); background: #fff; }
    .p-flow__panels { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-card); margin-bottom: var(--sp-4); }
    .p-flow__panel-wrap { position: relative; }
    .p-flow__panel-img { width: 100%; height: auto; display: block; border-radius: 10px; box-shadow: 0 6px 18px rgba(0, 163, 224, .18); }
    .p-flow__badge { position: absolute; top: -48px; right: -26px; width: 116px; height: 116px; background: #ffff00; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; }
    .p-flow__badge-text { font-family: var(--font-jp); font-weight: 700; font-size: 2.4rem; color: var(--c-blue); letter-spacing: .05em; line-height: 1; }
    .p-flow__badge-up { font-family: var(--font-en); font-weight: 700; font-size: 4rem; color: var(--c-blue); letter-spacing: .04em; line-height: 1; text-transform: uppercase; }
    @media (max-width: 768px) {
      .p-flow .c-section-head__title { font-size: 3.75rem; }
      .p-flow__panels { grid-template-columns: 1fr; }
      .p-flow__badge { top: -36px; right: -8px; width: 90px; height: 90px; }
      .p-flow__badge-text { font-size: 1.7rem; }
      .p-flow__badge-up { font-size: 2.8rem; }
    }
    /* バナースワイパー下に余白 */
    .banner2.swiper--banner { padding-bottom: 40px; }
    /* ===== キャンペーン（記念感謝祭・クーポン券型） ===== */
    /* クーポンコピーボタン共通 */
    .lp2-coupon__copy { border: none; background: #00a3e0; color: #fff; font-size: 1.4rem; font-weight: 700; border-radius: 6px; padding: 6px 14px; cursor: pointer; transition: opacity .2s, background .2s; }
    .lp2-coupon__copy:hover { opacity: .85; }
    .lp2-coupon__copy.is-copied { background: #4caf50; opacity: 1; }
    .cmpb { position: relative; overflow: hidden; padding: 50px 16px; text-align: center;
      background:
        repeating-conic-gradient(from 0deg at 50% 34%, rgba(255,255,255,.12) 0deg 3.2deg, rgba(255,255,255,0) 3.2deg 11deg),
        radial-gradient(circle at 50% 34%, #3cb4ea 0%, #7ecef4 52%, #7ecef4 100%); }
    .cmpb__inner { position: relative; z-index: 1; max-width: 1040px; margin: 0 auto; background: #fff; border-radius: 20px; padding: 34px 48px; text-align: center; box-shadow: 0 10px 26px rgba(0,40,70,.22); }
    /* 紙吹雪アニメーション */
    .cmpb__confetti { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
    .cmpb__confetti span { position: absolute; top: -24px; width: 11px; height: 17px; border-radius: 2px; opacity: .95; will-change: transform; animation-name: cmpbConfetti; animation-timing-function: linear; animation-iteration-count: infinite; }
    @keyframes cmpbConfetti { 0% { transform: translate3d(0, -24px, 0) rotate(0deg); opacity: 0; } 8% { opacity: .95; } 100% { transform: translate3d(24px, 780px, 0) rotate(740deg); opacity: .95; } }
    @media (prefers-reduced-motion: reduce) { .cmpb__confetti { display: none; } }
    .cmpb__sub { position: relative; z-index: 1; font-size: 2.6rem; font-weight: 700; color: #fff; text-shadow: 0 1px 3px rgba(0,40,70,.35); }
    .cmpb__title { position: relative; z-index: 1; margin: 16px 0 18px; line-height: 1; }
    .cmpb__title-svg { display: block; width: min(560px, 90%); height: auto; margin: 0 auto; filter: drop-shadow(0 3px 2px rgba(80,45,0,.3)); }
    .cmpb__lead { font-size: 1.7rem; font-weight: 700; color: #333; line-height: 1.5; margin-bottom: 10px; }
    /* 3,000円OFF（シンプル表示・数字=欧文和文合成ゴシック） */
    .cmpb__off { font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Noto Sans JP", sans-serif; font-weight: 700; line-height: 1.1; margin: 4px 0 22px; }
    .cmpb__off-num { color: #ff6607; font-size: 6rem; }
    .cmpb__off-yen { color: #ff6607; font-size: 3.4rem; }
    .cmpb__off-label { color: #00a3e0; font-size: 3.4rem; margin-left: .12em; }
    .cmpb__tickets { display: flex; gap: 26px; justify-content: center; margin-bottom: 14px; }
    .cmpb__ticket { flex: 1; max-width: 460px; display: flex; flex-direction: column; background: #fffdf5; border: 2px solid #fdd000; border-radius: 14px; position: relative; }
    .cmpb__ticket-main { padding: 20px 16px 14px; }
    .cmpb__ticket-stub { padding: 16px 16px 18px; border-top: 2px dashed #d9b94e; position: relative; }
    .cmpb__ticket-stub::before, .cmpb__ticket-stub::after { content: ""; position: absolute; top: -12px; width: 22px; height: 22px; border-radius: 50%; background: #ffffff; }
    .cmpb__ticket-stub::before { left: -12px; }
    .cmpb__ticket-stub::after { right: -12px; }
    .cmpb__cn { font-size: 2rem; font-weight: 700; color: #00a3e0; margin-bottom: 6px; }
    .cmpb__pr { font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Noto Sans JP", sans-serif; font-size: 2.4rem; font-weight: 700; }
    .cmpb__old { color: #888; text-decoration: line-through; font-size: .8em; font-weight: 500; }
    .cmpb__new { color: #ff6607; }
    .cmpb__cl { display: block; font-size: 1.3rem; color: #666; margin-bottom: 4px; }
    .cmpb__cd { font-size: 2.2rem; font-weight: 700; letter-spacing: .06em; vertical-align: middle; }
    .cmpb__copy { margin-left: 10px; vertical-align: middle; }
    .cmpb__period { font-size: 1.6rem; font-weight: 700; margin: 8px 0 4px; }
    .cmpb__note { font-size: 1.3rem; color: #666; line-height: 1.6; }
    @media (max-width: 767px) {
      .cmpb__inner { padding: 24px 16px; }
      .cmpb__sub { font-size: 1.9rem; }
      .cmpb__title { font-size: 3.4rem; }
      .cmpb__off-num { font-size: 4.4rem; }
      .cmpb__off-yen, .cmpb__off-label { font-size: 2.6rem; }
      .cmpb__tickets { flex-direction: column; align-items: center; }
      .cmpb__ticket { width: 100%; max-width: 100%; }
    }
    /* 「全身」※注記 */
    .explanation-intro__note { display: inline-block; font-size: 1.3rem; font-weight: 400; color: #666; margin-left: .3em; vertical-align: baseline; }
    /* がんの検出率（p-detail移植・本LP最適化） */
    .p-detail__box { max-width: 1000px; margin: 24px auto; }
    .p-detail__box-head { text-align: center; margin-bottom: 18px; }
    .p-detail__box-title { font-size: 2.8rem; font-weight: 700; color: #00a3e0; line-height: 1.3; }
    .p-detail__box-sub { font-size: 1.4rem; color: #555; line-height: 1.5; margin-top: .4em; }
    .p-detail__detect-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
    .p-detail__detect-card { display: flex; align-items: center; gap: 10px; background: #f6fbfe; border: 1px solid #cdebf7; border-radius: 12px; padding: 12px 16px; }
    .p-detail__detect-icon-wrap { flex-shrink: 0; width: 46px; }
    .p-detail__detect-icon { width: 100%; height: auto; display: block; }
    .p-detail__detect-name { flex: 1; font-size: 1.6rem; font-weight: 700; color: #333; text-align: left; }
    .p-detail__detect-right { flex-shrink: 0; text-align: right; }
    .p-detail__detect-pct { font-family: "Barlow", sans-serif; font-weight: 700; font-size: 3.2rem; color: #00a3e0; line-height: 1; }
    .p-detail__detect-pct small { font-size: .5em; font-weight: 700; margin-left: 1px; }
    .p-detail__detect-n { font-size: 1.1rem; color: #888; }
    .p-detail__detail-link { text-align: right; margin: 14px auto 0; max-width: 1000px; }
    .p-detail__detail-link a { font-size: 1.4rem; font-weight: 700; color: #00a3e0; text-decoration: underline; }
    /* セクション見出しは丸→角丸帯（PCのみ。SPは元から角丸矩形） */
    @media (min-width: 768px) {
      .explanation-unit__title { width: -moz-fit-content; width: fit-content; max-width: 100%; height: auto; border-radius: 28px; padding: 28px 48px; margin: 0 auto 70px; }
      .explanation-unit__title .explanation-unit__title--title { font-size: 2.6rem; white-space: nowrap; }
      .merit__list--title.merit__list--title--ai { font-size: 1.85rem; line-height: 1.35; }
    }
    @media (max-width: 767px) {
      .p-detail__box-title { font-size: 2.2rem; }
      .p-detail__detect-grid { grid-template-columns: 1fr; gap: 10px; }
    }
    /* 検体数アワード（FVアワード風・月桂樹） */
    .lp2-award { text-align: center; background: #fff; padding: 30px 16px 46px; }
    .lp2-award__lead { font-size: 1.9rem; font-weight: 700; color: #00a3e0; margin-bottom: -2px; }
    .lp2-award__num { position: relative; display: inline-flex; align-items: baseline; justify-content: center; color: #00a3e0; line-height: 1; padding: 0 60px; margin: 2px 0; }
    .lp2-award__num::before, .lp2-award__num::after { content: ""; position: absolute; top: 50%; width: 34px; height: 86px; background: url(/new-assets/img/top/img-laurels.svg) no-repeat center / contain; }
    .lp2-award__num::before { left: 8px; transform: translateY(-50%); }
    .lp2-award__num::after { right: 8px; transform: translateY(-50%) scaleX(-1); }
    .lp2-award__val { font-family: "Barlow", sans-serif; font-style: italic; font-weight: 700; font-size: 7rem; letter-spacing: .04em; }
    .lp2-award__unit { font-size: 4.5rem; font-weight: 700; }
    .lp2-award__sup { font-size: 1.8rem; font-weight: 700; align-self: flex-start; margin-left: 2px; }
    .lp2-award__note { font-size: 1.3rem; color: #666; margin-top: 10px; }
    @media (max-width: 767px) {
      .lp2-award__num { padding: 0 46px; }
      .lp2-award__num::before, .lp2-award__num::after { width: 26px; height: 64px; }
      .lp2-award__val { font-size: 5rem; }
      .lp2-award__unit { font-size: 3.2rem; }
    }
