/* =========================================================
   Reset / 基本設定（html, :root, body など）
   ========================================================= */

:root {
    --maxw: 1200px;
    --kp-blue: #0068b7; /* 見出し主色 */
    --kp-blue-d: #004d86; /* 濃いめの青 */
    --kp-blue-l: #cce4f8; /* 罫線・下線の淡色 */
    --kp-hl: #fff6a6; /* テキストの下線ハイライト */
    --kp-box-bg: #f6fbff; /* 情報ボックスの背景 */
    --kp-box-line: #b7dcff; /* 情報ボックスのライン */
    --kp-text: #222; /* 本文色 */
    --sticky-offset: 118px; /* グローバルヘッダーの高さ */
    scroll-behavior: smooth;
}

@media (min-width: 1028px) {
  :root {
    scroll-padding-top: var(--sticky-offset); /* =118px */
  }
}

@media (min-width: 601px) and (max-width: 1027px) {
  :root {
    scroll-padding-top: calc(var(--sticky-offset) + 100px); 
  }
}

@media (max-width: 600px) {
  :root {
    scroll-padding-top: 0;
  }
}

.kp-sub {
    font-size: 1.2rem;
    font-weight: 700;
    color: #004d86;
    margin: 1.8em 0 1.2em;
    border-bottom: 2px solid #cce4f8;
    padding-bottom: .25em;
}
.kids-h2, .kp-sub {
    line-height: 1.35;
    scroll-margin-top: 118px;
}
ruby {
    ruby-position: over;
}
rt {
    color: #004d86;
    letter-spacing: 0.02em;
    font-size: 0.6em;
    line-height: 1;
}
.kids-lead {
    font-size: 1.05rem;
    color: #222;
    margin-bottom: 2em;
    line-height: 1.9;
}


.kids-page {
    --blue: #1e88e5;
    --green: #2e7d32;
    --orange: #ef6c00;
    --purple: #7b1fa2;
    --teal: #00897b;
    --pink: #d81b60;
    --ink: #223;
    --muted: #5b6b7a;
    --bg: #fff;
    --chip: #f6fafe;
    --shadow: 0 8px 20px rgba(0, 0, 0, .08);
    --r: 18px;
    --maxw: 1200px;
}
.kids-page * {
    box-sizing: border-box;
}
.kids-main {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 1rem;
    color: var(--ink);
    font-family: "Noto Sans JP", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", Meiryo, sans-serif;
}
.kids-section {
    position: relative;
    padding: 3.2rem 0;
    scroll-margin-top: 120px;
}
.kids-section .kids-h2 {
    margin: 0 0 1.1rem;
    font-size: clamp(1.5rem, 2.6vw, 2.1rem);
    letter-spacing: .01em;
    color: var(--blue);
}
.kids-h2 {
    font-size: 1.6rem;
    color: var(--kp-blue);
    border-left: 6px solid var(--kp-blue);
    padding-left: .6em;
    margin: 0 0 1rem 0;
    font-weight: 700;
}
.kids-text {
    color: var(--kp-text);
    font-size: 1.06rem;
    line-height: 1.9;
    margin-inline: auto;
}
.kids-text h3 {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--kp-blue-d);
    margin: 1.6em 0 .6em;
    padding-bottom: .25em;
    border-bottom: 2px solid var(--kp-blue-l);
}
.kids-text h4 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--kp-blue);
    margin: 1.4em 0 .4em;
    padding-left: .55em;
    border-left: 4px solid var(--kp-blue-l);
}
.kids-text h5 {
    font-size: 1.0rem;
    font-weight: 700;
    color: var(--kp-blue-d);
    margin: 1.1em 0 .3em;
    padding-bottom: .2em;
    border-bottom: 1px dashed var(--kp-blue-l);
}
.kids-text p {
    margin-top: .6em;
}

@media (max-width: 720px) {
    .kids-h2 {
        font-size: 1.4rem;
    }
    .kids-text h3 {
        font-size: 1.15rem;
    }
    .kids-text h4 {
        font-size: 1.05rem;
    }
    .kids-text h5 {
        font-size: 1rem;
    }
}


@media (max-width: 600px) {
    .kids-section {
        scroll-margin-top: 180px;
    }
    .kids-h2, .kp-sub {
        scroll-margin-top: 24px;
    }
}

.caicm-letter {
        color: #ff0000;
}
/* =========================================================
   ヒーローセクション（.kids-hero〜）
   ========================================================= */

.kids-hero {
    position: relative;
    isolation: isolate;
    font-family: "Noto Sans JP", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic UI", "Yu Gothic", Meiryo, sans-serif;
    color: #16324f;
    --blue: #0068b7;
    --blue-weak: #e9f3fb;
    --accent: #ff9900;
    --ink: #1a2b3c;
    --muted: #425466;
    min-height: 40svh;
}
.kids-hero__inner {
    max-width: var(--maxw);
    margin: 0 auto;
    padding: 36px 16px 28px;
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 24px;
    align-items: center;
    min-height: 40svh;
}
.kids-hero__bg {
    position: absolute;
    inset: 0;
    z-index: -1;
    background: radial-gradient(1300px 440px at 10% -10%, #e6f2ff 0, transparent 60%), radial-gradient(900px 360px at 90% 0%, #eef8ff 0, transparent 60%), linear-gradient(180deg, #f5faff, #ffffff 40%);
}
.kids-hero h2 {
    margin: 0 0 8px;
    font-size: clamp(28px, 4.1vw, 44px);
    line-height: 1.25;
    letter-spacing: .02em;
    color: var(--blue);
}
.kids-hero__copy h2 rt, .kids-h2 ruby rt {
    font-size: 0.5em;
}
.kids-hero p.lead {
    margin: 10px 0 18px;
    font-size: clamp(16px, 1.6vw, 18px);
    color: var(--muted);
}
.kids-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}
.kids-hero__art {
    display: grid;
    place-items: center;
}
.chip {
    display: inline-block;
    padding: 14px 20px 6px;
    border-radius: 999px;
    font-weight: 700;
    background: #eef6ff;
    color: var(--blue);
    box-shadow: inset 0 -2px 0 rgba(255, 255, 255, .8);
}
.chip.caicm {
    padding: 10px 20px 11px;
}

@supports (-moz-appearance: none) {
    .chip {
        padding: 5px 20px 6px;
        height: 50px;
        line-height: 25px;
    }
}

.art-card {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.art-card img {
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
    margin: auto;
}

@media (prefers-reduced-motion: no-preference) {
    .motion-fadeup {
        transform: translateY(8px);
        transition: opacity .6s ease, transform .6s ease;
    }
    .art-card {
        animation: heroIn .7s ease both .12s;
    }
    @keyframes heroIn {
        from {
            opacity: 0;
            transform: translateY(8px) scale(0.98);
        }
        to {
            opacity: 1;
            transform: none;
        }
    }
}

@media (max-width: 880px) {
    .kids-hero__inner {
        grid-template-columns: 1fr;
        padding-block: 28px 22px;
        min-height: 48svh;
    }
    .kids-hero__art {
        order: -1;
    }
    .kids-hero {
        min-height: 48svh;
    }
}
.kids-hero__wave {
    display: block;
    inline-size: 100%;
    block-size: 160px;
    background: url("data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%221440%22%20height%3D%22160%22%20viewBox%3D%220%200%201440%20160%22%3E%3Cdefs%3E%3ClinearGradient%20id%3D%22waveSoft%22%20x1%3D%220%22%20y1%3D%220%22%20x2%3D%220%22%20y2%3D%221%22%3E%3Cstop%20offset%3D%220%25%22%20stop-color%3D%22%23e4f7ff%22/%3E%3Cstop%20offset%3D%2260%25%22%20stop-color%3D%22%23bce8ff%22/%3E%3Cstop%20offset%3D%22100%25%22%20stop-color%3D%22%2390dbff%22/%3E%3C/linearGradient%3E%3C/defs%3E%3Cpath%20fill%3D%22url(%23waveSoft)%22%20d%3D%22M0%2C80%20Q90%2C10%20180%2C80%20T360%2C80%20T540%2C80%20T720%2C80%20T900%2C80%20T1080%2C80%20T1260%2C80%20T1440%2C80%20L1440%2C160%20L0%2C160%20Z%22/%3E%3C/svg%3E") center/cover no-repeat;
}


/* =========================================================
   ページ内ナビ（.kids-page-nav〜）
   ========================================================= */
.kids-page-nav ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: .8rem;
    list-style: none;
    margin: 0;
    padding: 0;
}
.kids-page-nav a {
    display: inline-block;
    text-decoration: none;
    background: #fff;
    border: 2px solid var(--kp-blue, #0068b7);
    color: var(--kp-blue-d, #004d86);
    border-radius: 9999px;
    padding: .45rem 1rem;
    font-size: .95rem;
    font-weight: 700;
    transition: all .2s ease;
}
.kids-page-nav a:hover, .kids-page-nav a:hover ruby rt, .kids-page-nav a:focus {
    background: var(--kp-blue, #0068b7);
    color: #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .08);
}
.kids-page-nav ul li:nth-child(4) a, .kids-page-nav ul li:nth-child(6) a {
    padding: .6rem 1rem .6rem;
}

@media (max-width:600px) {
    .kids-page-nav a {
        text-align: center;
        font-size: 1rem;
    }
}

.kids-page-nav-wrap {
    position: relative;
    z-index: 10;
    margin: 1.5rem 0 2rem;
}
.kids-page-nav {
    position: -webkit-sticky;
    position: sticky;
    top: var(--sticky-offset);
    z-index: 1000;
    background: #f5fbff;
    border: 1px solid #e0f0fa;
    padding: 1rem 1.5rem;
    margin: 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .05);
    width: 100%;
}
.kids-page-nav.is-stuck {
    box-shadow: 0 4px 14px rgba(0, 0, 0, .08);
}

@media (min-width: 601px) {
    .kids-page-nav-wrap {
        margin: 0 0 2rem;
        position: relative;
        z-index: 10;
        min-height: 180px;
    }
    .kids-page-nav ul {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: .8rem;
        list-style: none;
        margin: 0;
        padding: 0;
    }
    .kids-page-nav a {
        display: inline-block;
        text-decoration: none;
        background: #fff;
        border: 2px solid var(--kp-blue, #0068b7);
        color: var(--kp-blue-d, #004d86);
        border-radius: 9999px;
        padding: .9rem 1rem .3rem;
        font-size: .95rem;
        font-weight: 700;
        transition: all .2s ease;
    }
    .kids-page-nav a:hover, .kids-page-nav a:focus, .kids-page-nav a:focus ruby {
        background: var(--kp-blue, #0068b7);
        color: #fff;
    }
    .kids-page-nav a:focus ruby rt, .kids-page-nav a:hover ruby rt {
        color: #fff;
    }
}

details.kids-page-nav.is-collapsible summary {
    text-align: center;
    padding-bottom: 10px;
    cursor: pointer;
}
.kids-page-nav ruby rt, .kp-sub ruby rt {
    font-size: 0.7em;
    color: #005eb8;
}

@supports (-moz-appearance: none) {
    .kids-page-nav.is-collapsible a {
        padding: .3rem .75rem .1rem;
        line-height: 25px;
        height: 50px;
    }
}

@media (max-width: 600px) {
    .kids-page-nav {
        position: static;
        background: #f5fbff;
        border: 1px solid #e0f0fa;
        border-radius: 0;
        padding: .25rem .75rem;
        overflow: visible;
    }
    .kids-page-nav-wrap {
        height: 146px;
        margin: 0;
    }
    .kids-page-nav.is-collapsible > summary {
        list-style: none;
        outline: none;
        font-weight: 700;
        color: var(--kp-blue-d, #004d86);
        padding: .6rem .2rem;
    }
    .kids-page-nav.is-collapsible > summary::-webkit-details-marker {
        display: none;
    }
    .kids-page-nav.is-collapsible > summary::after {
        content: "＋";
        font-weight: 900;
        right: 20px;
        position: absolute;
    }
    .kids-page-nav.is-collapsible[open] > summary::after {
        content: "－";
    }
    .kids-page-nav.is-collapsible > ul {
        display: none;
        list-style: none;
        margin: .4rem 0 .6rem;
        padding: 0;
        gap: .5rem;
    }
    .kids-page-nav.is-collapsible[open] > ul {
        display: flex;
        overflow-x: auto;
        white-space: nowrap;
        scrollbar-width: thin;
        justify-content: flex-start;
        flex-wrap: nowrap;
    }
    .kids-page-nav.is-collapsible a {
        display: inline-block;
        text-decoration: none;
        font-weight: 700;
        border: 2px solid var(--kp-blue, #0068b7);
        border-radius: 9999px;
        font-size: .95rem;
        padding: .9rem .75rem .1rem;
        line-height: 25px;
        height: 50px;
    }
    
    @supports (-moz-appearance: none) {
        .kids-page-nav.is-collapsible a {
            padding: 0.1rem 1rem .6rem;
            height: 46px;
            line-height: 40px;
        }
    }
}

@media (max-width: 1028px) {
    :root {
        --sticky-offset: 80px;
    }
}

/* =========================================================
   カード / グリッド（.kids-card, .kids-grid〜）
   ========================================================= */

.kids-card {
    text-align: center;
    grid-column: span 4;
    border-radius: var(--r);
    padding: 1rem;
    overflow: hidden;
    position: relative;
    padding-top: 2em;
}
.kids-card.two-images {
    width: 80%;
}
.kids-card.two-images .image-pair {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}
.kids-card.two-images .image-pair img {
    width: 32%;
    height: auto;
}
.kids-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(12, 1fr);
}

.kids-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: var(--r);
    pointer-events: none;
}
.kids-card img {
    width: 100%;
    max-width: 520px;
    height: auto;
    display: block;
    border-radius: 14px;
    background: #fff;
    box-shadow: 0 3px 10px rgba(0, 0, 0, .05);
    margin: 0 auto;
}
.kids-card figcaption {
    margin-top: .55rem;
    font-size: 1rem;
    color: #2a2a2a;
}

@media (max-width:960px) {
    .kids-card {
        grid-column: span 6;
    }
}
@media (max-width:680px) {
    .kids-card {
        grid-column: span 12;
    }
}

.kids-reason-cards {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.8rem;
    margin-top: 2rem;
}
.reason-card {
    flex: 1 1 280px;
    max-width: 320px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.05);
    padding: 1.2rem 1.4rem 1.6rem;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.reason-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}
.reason-card figure {
    margin: 0 auto 0.8rem;
    max-width: 260px;
}
.reason-card img {
    width: 100%;
    height: auto;
    display: block;
}
.reason-card h4 {
    font-size: 1.05rem;
    color: var(--kp-blue-d, #004d86);
    font-weight: 700;
    margin-bottom: 0.6rem;
}
.reason-card p {
    line-height: 1.8;
    color: #222;
    font-size: 0.95rem;
    text-align: left;
}

@media (max-width: 720px) {
    .kids-reason-cards {
        flex-direction: column;
        align-items: center;
    }
    .reason-card {
        max-width: 90%;
    }
}

.kids-route-cards {
    display: grid;
    gap: 1.8rem;
    margin-top: 1.4rem;
}

@media (min-width:1024px) {
    .kids-route-cards {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width:720px) and (max-width:1023px) {
    .kids-route-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}

.route-card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 12px;
    box-shadow: 0 3px 8px rgba(0, 0, 0, .05);
    padding: 1.2rem 1.2rem 1.4rem;
    display: flex;
    flex-direction: column;
    gap: .6rem;
    transition: transform .2s ease, box-shadow .2s ease;
}
.route-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(0, 0, 0, .08);
}
.route-fig {
    margin: 0 auto .4rem;
    max-width: 180px;
}
.route-fig img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
}
.route-card h5 {
    font-size: 1.05rem;
    color: var(--kp-blue, #0068b7);
    font-weight: 700;
    margin: 0;
}
.route-card p {
    margin: 0;
    line-height: 1.9;
    color: #222;
    font-size: .95rem;
}
.route-card small {
    color: #666;
    font-size: .9em;
}
.mark-icon {
    position: absolute;
    top: 0.5em;
    left: 0.5em;
    z-index: 5;
}
.mark-icon .circle {
    display: inline-block;
    width: 2em;
    height: 2em;
    line-height: 2em;
    border-radius: 50%;
    text-align: center;
    font-weight: bold;
    color: #fff;
    font-size: 1.2em;
}
.mark-icon .circle.green {
    background-color: #4CAF50;
}
.mark-icon .circle.red {
    background-color: #f44336;
}

/* =========================================================
   ステップブロック（.kids-steps, .step-head〜）
   ========================================================= */

.kids-steps {
    display: grid;
    gap: 2rem;
    counter-reset: step;
    list-style: none;
    padding: 0;
    margin: 0;
}
.kids-steps > li {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 10px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .03);
    padding: 1.5rem 1.2rem 1.6rem;
    counter-increment: step;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}
.step-head {
    display: flex;
    align-items: center;
    gap: .6rem;
}
.kids-card .step-head {
    display: flex;
    gap: 0.3em;
    margin-bottom: 0.5em;
    text-align: left;
    min-height: 3.8em;
}
.kids-card .step-head h4 {
    margin: 0;
    font-size: 1rem;
    line-height: 1.3;
}
.step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.8rem;
    height: 1.8rem;
    border-radius: 50%;
    font-weight: 700;
    color: #fff;
    background: var(--kp-blue, #0068b7);
    font-size: 1rem;
    flex-shrink: 0;
}
.kids-steps h4 {
    font-size: 1.1rem;
    color: var(--kp-blue, #0068b7);
    font-weight: 700;
    margin: 0;
}
.step-media {
    margin: 0;
    border-radius: 8px;
    overflow: hidden;
}
.step-media img {
    width: 100%;
    height: auto;
    display: block;
}
.kids-steps p {
    margin: 0;
    line-height: 1.9;
    color: #222;
}

@media (min-width: 1024px) {
    .kids-steps {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (min-width: 720px) and (max-width: 1023px) {
    .kids-steps {
        grid-template-columns: repeat(2, 1fr);
    }
}

.kids-step-block {
    background: #e9f6ff;
    border-radius: 12px;
    padding: 1.2em 1.5em 1.6em;
    margin: 2em 0;
}
.kids-step-block > p {
    margin-top: 1.2em;
}
.kids-step-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #0077b6;
    margin: 0 0 0.6em;
}
.kids-step-img {
    width: 180px;
    height: auto;
    margin: 0.2em 0 1em 1.2em;
}
.kids-detail-title {
    font-size: 1.1rem;
    font-weight: 700;
    color: #005580;
    background: #e0f4ff;
    border-left: 6px solid #2a96d4;
    padding: 0.9em 1em 0.4em;
    margin: 1.4em 0 0.8em;
    border-radius: 6px;
}

@media (max-width: 720px) {
    .kids-step-img {
        float: none;
        display: block;
        margin: 0 auto 1em;
    }
}
/* =========================================================
   テーブル / 比較ブロック（.kids-table〜）
   ========================================================= */

.kids-table {
    width: 100%;
    border-collapse: collapse;
    margin: 2em 0;
    font-size: 0.95rem;
    line-height: 1.8;
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .05);
}
.kids-table thead {
    background: var(--kp-blue, #0068b7);
    color: #fff;
    text-align: center;
}
.kids-table th, .kids-table td {
    padding: 0.9em 1em;
    border-bottom: 1px solid #e5e5e5;
    vertical-align: top;
}
.kids-table th {
    font-weight: 700;
    font-size: 1rem;
}
.kids-table thead tr th ruby rt {
    color: #fff;
}
.kids-table tbody tr:nth-child(even) {
    background: #f9fcff;
}
.kids-table td:first-child {
    width: 22%;
    background: #f0f8ff;
    font-weight: 600;
    color: var(--kp-blue-d, #004d86);
}
.kids-table small {
    color: #666;
    font-size: 0.85em;
}
.kids-table th:nth-child(1) {
    width: 5%;
}
.kids-table th:nth-child(2) {
    width: 45%;
}
.kids-table th:nth-child(3) {
    width: 50%;
}

@media (max-width: 720px) {
    .kids-table thead {
        display: none;
    }
    .kids-table, .kids-table tbody, .kids-table tr, .kids-table td {
        display: block;
        width: 100%;
    }
    .kids-table tr {
        padding: .6em .8em;
        box-shadow: 0 1px 6px rgba(0, 0, 0, .03);
        margin-bottom: 1.4em;
        border: 2px solid #cce4f8;
        border-radius: 12px;
        background: #fff;
    }
    .kids-table td:first-child {
        font-weight: 700;
        color: var(--kp-blue-d);
        padding-bottom: .3em;
        border: none;
        width: 50%;
        font-size: 1.05rem;
        background: #eaf4ff;
        border-radius: 12px;
        padding: .9em .8em .6em;
        margin-bottom: .4em;
        text-align: center;
    }
    .kids-table td:not(:first-child) {
        border: none;
        padding-top: 0;
    }
    .kids-table td:nth-child(2)::before {
        content: "ウイルス：";
        display: block;
        font-weight: 700;
        color: #0068b7;
    }
    .kids-table td:nth-child(3)::before {
        content: "細菌：";
        display: block;
        font-weight: 700;
        color: #007a33;
    }
}
.kids-compare-images {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: flex-start;
    gap: 1.5rem;
    margin: 2rem 0 3rem;
    text-align: center;
}
.kids-compare-images figure {
    flex: 1 1 200px;
    max-width: 280px;
}
.kids-compare-images figure.wide {
    flex-basis: 100%;
    max-width: 640px;
}
.kids-compare-images img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .05);
    background: #fff;
}
.kids-compare-images figcaption {
    margin-top: 0.4em;
    font-size: 0.9rem;
    color: var(--kp-blue-d, #004d86);
    font-weight: 600;
}
@media (max-width: 720px) {
    .kids-compare-images {
        flex-direction: column;
        align-items: center;
    }
    .kids-compare-images figure, .kids-compare-images figure.wide {
        max-width: 90%;
    }
}

/* =========================================================
   ユーティリティ（.for_sp, .sr-only など）
   ========================================================= */

.for_sp_br {
    display: none;
}

@media (max-width: 1024px) {
    .for_sp_br {
        display: inline;
    }
}

.for_pc {
    display: block;
}
.for_sp {
    display: none;
}

@media (max-width: 1024px) {
    .for_sp {
        display: block;
    }
    .for_pc {
        display: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    * {
        transition: none !important;
        animation: none !important;
    }
}





