@charset "UTF-8";


/* slider
---------------------------------------*/

.sec02 .slider {
    width: 100%;
    margin: 40px auto;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.sec02 .slider .swiper {
    overflow: visible;
}

.sec02 .slider .swiper-wrapper {
    display: flex;
    gap: 10px;
    width: max-content;
    animation: slideScroll 30s linear infinite;
}

.sec02 .slider .swiper-slide img {
    width: 100%;
    object-fit: cover;
}


@keyframes slideScroll {
0% {
        transform: translateX(0);
    }
100% {
        transform: translateX(-50%);
    }
}

.sec02 .slider .swiper-slide {
    text-align: center;
    width: auto;
    flex-shrink: 0;
}


.sec03 .slider {
    width: 100%;
    margin: 80px auto 10px;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.sec03 .slider .swiper {
    overflow: visible;
}

.sec03 .slider .swiper-wrapper {
    display: flex;
    gap: 20px;
    width: max-content;
    animation: slideScroll 30s linear infinite;
}

.sec03 .slider .swiper-slide img {
    width: 100%;
    object-fit: cover;
    border-radius: 5px;
    border: 5px solid transparent;
    background: linear-gradient(#fff, #fff) padding-box,
                linear-gradient(90deg, #1be7f5 0%, #2483f8 100%) border-box;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

@keyframes slideScroll {
0% {
        transform: translateX(0);
    }
100% {
        transform: translateX(-50%);
    }
}

.sec03 .slider .swiper-slide {
    text-align: center;
    width: 250px;
    flex-shrink: 0;
}

@media screen and (max-width: 768px) {
.sec02 .slider {
    margin: 20px auto 10px;
}

.sec02 .slider .swiper-wrapper {
    gap: 5px;
    animation-duration: 30s;
}

.sec02 .slider .swiper-slide {
    height: auto;
    aspect-ratio: 105/59;
}
.sec02 .slider .swiper-slide img {
    width: 100%;
    max-width: 100%;
    height: auto;
}
}

@media screen and (max-width: 768px) {
.sec03 .slider {
    margin: 40px auto 10px;
}

}



/* mainVisual
---------------------------------------*/
.mainVisual {
    padding: 50px 0 70px;
    background-size: cover;
    background: url("../images/mv-bg.png") no-repeat center right;
    position: relative;
    overflow: hidden;
}

.mainVisual .inner {
    width: 1180px;
    max-width: 92%;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.mainVisual .flex {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 30px;
}

/* ===== 左ブロック ===== */
.mainVisual .left {
    flex: 1;
    max-width: 660px;
}

/* メインコピー */
.mainVisual .left h1 {
    font-weight: 800;
    color: #111;
    letter-spacing: 0.02em;
    margin-bottom: 15px;
}

.mainVisual .left h1 > span {
    display: block;
}

/* 「気になる銘柄の」 */
.mainVisual .left h1 .row1 {
    font-size: 48px;
    margin-bottom: 8px;
}

/* 「リスク分析」+ 「に」 */
.mainVisual .left h1 .row2 {
    font-size: 96px;
    margin-bottom: 6px;
    display: flex;
    align-items: flex-end;
    gap: 6px;
}

.mainVisual .left h1 .row2 .suffix {
    font-size: 48px;
}

/* 「AI」 + 「を正しく / 使えていますか？」 */
.mainVisual .left h1 .row3 {
    display: flex;
    align-items: center;
    gap: 12px;
    position: relative;
}

.mainVisual .left h1 .row3 .sub {
    display: flex;
    flex-direction: column;
    gap: 2px;
    position: relative;
}

.mainVisual .left h1 .row3 .sub span {
    font-size: 54px;
    background: linear-gradient(180deg, #1be7f5 0%, #2483f8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    display: inline-block;
    width: fit-content;
}


/* 強調グラデーション部 */
.mainVisual .left h1 .grad {
    display: inline-block;
    background: linear-gradient(180deg, #1be7f5 0%, #2483f8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    line-height: 1;
}

/* 「AI」だけ超大きく */
.mainVisual .left h1 .ai {
    font-size: 160px;
    font-family: "Helvetica Neue", Arial, sans-serif;
    color: #F70B78!important;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1;
}

/* ===== カテゴリリスト ===== */
.mainVisual .cat-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, auto);
    grid-auto-flow: column;
    gap: 10px 12px;
    list-style: none;
    padding: 0;
    margin: 0;
    max-width: 580px;
}

.mainVisual .cat-list li {
    position: relative;
    background: #000;
    color: #fff;
    border-radius: 999px;
    border: 2px solid #fff;
    padding: 0px 14px 0px 55px;
    font-size: 16px;
    font-weight: 700;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
    display: flex;
    align-items: center;
    min-height: 38px;
}

.mainVisual .cat-list li::before {
    content: "";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.mainVisual .cat-list .cat01::before { background-image: url("../images/mv-icon01.png"); }
.mainVisual .cat-list .cat02::before { background-image: url("../images/mv-icon02.png"); }
.mainVisual .cat-list .cat03::before { background-image: url("../images/mv-icon03.png"); }
.mainVisual .cat-list .cat04::before { background-image: url("../images/mv-icon04.png"); }
.mainVisual .cat-list .cat05::before { background-image: url("../images/mv-icon05.png"); }
.mainVisual .cat-list .cat06::before { background-image: url("../images/mv-icon06.png"); }
.mainVisual .cat-list .cat07::before { background-image: url("../images/mv-icon07.png"); }
.mainVisual .cat-list .cat08::before { background-image: url("../images/mv-icon08.png"); }
.mainVisual .cat-list .cat09::before { background-image: url("../images/mv-icon09.png"); }

/* ===== 右ブロック（スマホ＋パンフ画像） ===== */
.mainVisual .right {
    flex-shrink: 0;
    width: 560px;
    text-align: center;
    align-self: center;
}

.mainVisual .right img {
    margin-top: 50px;
    max-width: 100%;
    height: auto;
    display: block;
    margin-left: auto;
}

/* ===== ステップ ===== */
.mainVisual .step {
    margin-top: 30px;
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    gap: 0;
}

.mainVisual .step dl {
    flex: 1;
    background: #fff;
    border-radius: 12px;
    padding: 18px 0 20px;
    text-align: center;
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.08);
    position: relative;
    border: 2px solid transparent;
    background:
        linear-gradient(#fff, #fff) padding-box,
        linear-gradient(180deg, #1be7f5 0%, #2483f8 100%) border-box;
    margin: 0 16px 0 0;
}

.mainVisual .step dl:last-child {
    margin-right: 0;
}

/* ステップ間の矢印 */
.mainVisual .step dl:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -16px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 12px 0 12px 16px;
    border-color: transparent transparent transparent #F70678;
    filter: drop-shadow(1px 2px 2px rgba(0, 0, 0, 0.15));
    z-index: 2;
}

.mainVisual .step dt {
    font-size: 20px;
    font-weight: 800;
    color: #2483f8;
    margin-bottom: 10px;
}

.mainVisual .step dd {
    width: 90%;
    margin: 0 auto;
}

.mainVisual .step dd.img {
    margin-bottom: 8px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.mainVisual .step dd.img img {
    max-width: 90%;
    height: auto;
    margin: 0 auto;
    display: block;
}

.mainVisual .step dd.text {
    font-size: 14px;
    font-weight: 600;
    color: #222;
    text-align: center;
}

/* ===== レスポンシブ：SP ===== */
@media screen and (max-width: 768px) {
.mainVisual {
        padding: 20px 0 30px;
        background-size: contain;
        background-position: top right;
    }

.mainVisual .inner {
        width: 90%;
        max-width: 90%;
    }

.mainVisual .flex {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

.mainVisual .left {
        order: 1;
        max-width: 100%;
        width: 100%;
        text-align: left;
    }

.mainVisual .left h1 {
        margin-bottom: 18px;
    }

.mainVisual .left h1 .row1 {
        font-size: 32px;
        margin-bottom: 4px;
    }

.mainVisual .left h1 .row2 {
        font-size: 56px;
        gap: 4px;
        margin-bottom: 4px;
    }

.mainVisual .left h1 .row2 .suffix {
        font-size: 32px;
        line-height: 1;
    }

.mainVisual .left h1 .row3 {
        gap: 8px;
    }

.mainVisual .left h1 .row3 .sub span {
        font-size: 24px;
    }

.mainVisual .left h1 .ai {
        font-size: 96px;
    }

    /* 右側（スマホ画像）はSPでは中央表示 */
.mainVisual .right {
        order: 2;
        width: 100%;
        max-width: 360px;
    }

.mainVisual .right img {
    width: 85%;
    margin: 0 auto 20px;
    }

    /* カテゴリリスト：2列・縦読み（5行 × 2列） */
.mainVisual .cat-list {
        order: 3;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(5, auto);
        grid-auto-flow: column;
        gap: 6px 6px;
        max-width: 100%;
        margin: 6px 0 0;
    }

.mainVisual .cat-list li {
        font-size: 16px;
        padding: 2px 10px 2px 54px;
        min-height: 34px;
    }

.mainVisual .cat-list li::before {
        left: 18px;
        width: 22px;
        height: 22px;
    }

    /* SPでleft内の順序を整える（h1 → cat-list） */
.mainVisual .left h1 {
        order: 1;
    }
.mainVisual .left .cat-list {
        order: 2;
    }

    /* ステップ：縦並び＋下矢印（画像左 / テキスト右） */
.mainVisual .step {
        margin-top: 24px;
        flex-direction: column;
        gap: 22px;
    }

.mainVisual .step dl {
        margin: 0;
        padding: 14px 16px;
        display: grid;
        grid-template-columns: 90px 1fr;
        grid-template-areas:
            "img title"
            "img text";
        align-items: center;
        column-gap: 16px;
        row-gap: 4px;
        text-align: left;
    }



.mainVisual .step dl:not(:last-child)::after {
        top: auto;
        right: 50%;
        bottom: -20px;
        transform: translateX(50%) rotate(90deg);
    }

.mainVisual .step dt {
        grid-area: title;
        font-size: 18px;
        margin-bottom: 0;
        text-align: left;
    }

.mainVisual .step dd {
        width: auto;
        margin: 0;
    }

.mainVisual .step dd.img {
        grid-area: img;
        height: auto;
        margin-bottom: 0;
    }

.mainVisual .step dd.img img {
        max-width: 100%;
        width: 80px;
        height: auto;
    }

.mainVisual .step dd.text {
        grid-area: text;
        font-size: 16px;
        text-align: left;
    }
}

@media screen and (max-width: 480px) {
.mainVisual .left h1 .row2 {
        font-size: 56px;
    }

.mainVisual .left h1 .row2 .suffix {
        font-size: 32px;
    }

.mainVisual .left h1 .row3 .sub span {
        font-size: 32px;
        line-height: 1.2;
    }

.mainVisual .left h1 .grad.ai {
        font-size: 80px;
    }
}

/* top-cta / cta（共通スタイル）
---------------------------------------*/
.top-cta,
.cta {
    background: linear-gradient(180deg, #102D60 0%, #000000 100%);
    padding: 60px 0 50px;
    position: relative;
    text-align: center;
    overflow: hidden;
}

/* 背景に薄いサーキット風のテクスチャを重ねる（任意） */
.top-cta::before,
.cta::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url("../images/cta-bg.png") no-repeat center center;
    background-size: cover;
    opacity: 0.35;
    pointer-events: none;
}

.top-cta .inner,
.cta .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

/* ＼100名様限定で永年無料の特別ご招待／ */
.top-cta h1,
.cta h1 {
    font-size: 32px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 22px;
    letter-spacing: 0.04em;
    text-shadow: 0 2px 6px rgba(0, 0, 0, 0.35);
    background: none;
    -webkit-background-clip: initial;
    -webkit-text-fill-color: initial;
    background-clip: initial;
}

/* 「特別分析レポート」を含む豪華4大特典付き！ */
.top-cta h2,
.cta h2 {
    width: 580px;
    display: inline-block;
    background: linear-gradient(180deg, #2eb6ff 0%, #1f6fd0 100%);
    color: #fff;
    font-size: 20px;
    padding: 14px 48px;
    margin: 0 auto -10px;
    border-radius: 4px;
    position: relative;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
}

/* h2下部のV字（吹き出し風） */
.top-cta h2::after,
.cta h2::after {
    content: "";
    position: absolute;
    bottom: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 12px 14px 0 14px;
    border-color: #1f6fd0 transparent transparent transparent;
}

/* メールアドレス入力 */
.top-cta input[type="text"],
.cta input[type="text"] {
    display: block;
    width: 100%;
    max-width: 720px;
    height: 78px;
    margin: 0 auto;
    padding: 0 24px;
    border: 2px solid #fff;
    border-radius: 4px;
    background: #fff;
    font-size: 18px;
    color: #222;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.08);
    box-sizing: border-box;
    outline: none;
}

.top-cta input[type="text"]::placeholder,
.cta input[type="text"]::placeholder {
    color: #b9b9b9;
}

.top-cta input[type="text"]:focus,
.cta input[type="text"]:focus {
    border-color: #2eb6ff;
}

/* メインCTAボタン（黄色） */
.top-cta .btn,
.cta .btn {
    display: inline-block;
    width: 100%;
    max-width: 720px;
    margin: 0 auto;
    padding: 0;
    background: none;
    border: none;
    box-shadow: none;
    transition: transform 0.25s ease, filter 0.25s ease;
}

.top-cta .btn:hover,
.cta .btn:hover {
    transform: translateY(-2px);
    filter: brightness(1.05);
}

.top-cta .btn img,
.cta .btn img {
    width: 100%;
    height: auto;
    display: block;
}

/* 注釈 */
.top-cta ul,
.cta ul {
    list-style: none;
    padding: 0;
    margin: 22px auto 0;
    text-align: center;
}

.top-cta ul li,
.cta ul li {
    color: #fff;
    font-size: 16px;
    font-weight: 400;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
    .top-cta,
.cta {
        padding: 40px 0 36px;
    }

    .top-cta .inner,
.cta .inner {
        width: 90%;
        max-width: 90%;
    }

    .top-cta h1,
.cta h1 {
        font-size: 20px;
        margin-bottom: 16px;
        letter-spacing: 0.02em;
    }

    .top-cta h2,
.cta h2 {
        font-size: 14px;
        padding: 11px 0;
        margin-bottom: 18px;
        max-width: 100%;
    }

    .top-cta h2::after,
.cta h2::after {
        bottom: -10px;
        border-width: 10px 11px 0 11px;
    }

    .top-cta input[type="text"],
.cta input[type="text"] {
        height: 56px;
        font-size: 16px;
        padding: 0 16px;
        margin-top: -18px;
    }

    .top-cta ul,
.cta ul {
        margin-top: 16px;
    }

    .top-cta ul li,
.cta ul li {
        font-size: 11px;
        text-align: left;
    }
}

@media screen and (max-width: 480px) {
    .top-cta h1,
.cta h1 {
        font-size: 24px;
    }

    .top-cta h2,
.cta h2 {
        font-size: 14px;
        padding: 10px 0;
    }
}

/* .cta 上部のリード見出し（同じAIアプリでも、「中身」で…） */
.cta h1.cta-lead {
    display: block;
    background: none;
    -webkit-background-clip: initial;
    -webkit-text-fill-color: initial;
    background-clip: initial;
    color: #fff;
    font-weight: 700;
    margin: 0 auto 36px;
    padding: 0 4%;
    text-align: center;
    text-shadow: none;
    letter-spacing: 0.02em;
    position: relative;
    z-index: 1;
}

.cta h1.cta-lead .small {
    display: block;
    font-size: 32px;
    font-weight: 600;
    margin-bottom: 22px;
}

.cta h1.cta-lead .main {
    display: block;
    font-size: 48px;
    font-weight: 800;
}

.cta h1.cta-lead .marker {
    background: linear-gradient(transparent 60%, #fff000 60%);
    padding: 0 4px;
}

@media screen and (max-width: 768px) {
.cta h1.cta-lead {
        margin-bottom: 26px;
    }

.cta h1.cta-lead .small {
    background: #fff;
    padding: 8px 0;
    color: #102D60;
    font-weight: 800;
        font-size: 16px;
        margin-bottom: 14px;
    }

.cta h1.cta-lead .main {
        font-size: 36px;
    }
    .cta h1.last{
        font-size: 20px;

    }
}


/* menseki（免責事項）
---------------------------------------*/
.menseki {
    background: #000;
    padding: 50px 0 60px;
}

.menseki h1 {
    font-size: 18px;
    text-align: center;
    color: #fff;
    margin-bottom: 30px;
}

.menseki .box {
    max-width: 960px;
    margin: 0 auto;
    background: #fff;
    padding: 20px 0;
}

.menseki .box-inner {
    max-width: 840px;
    margin: 0 auto;
}

.menseki .box-inner p {
    font-size: 14px;
}

@media screen and (max-width: 768px) {
.menseki {
        padding: 40px 0 50px;
    }

.menseki h1 {
        font-size: 16px;
        margin-bottom: 25px;
    }

.menseki .box {
        max-width: 90%;
        padding: 20px 0;
    }

.menseki .box-inner {
        max-width: 90%;
    }
.menseki .box-inner p {
        font-size: 14px;
    }
}

@media screen and (max-width: 480px) {
.menseki {
        padding: 30px 0 40px;
    }

.menseki h1 {
        margin-bottom: 20px;
    }
}


/* add
---------------------------------------*/
.add {
    background: #fff url('../images/bg.png') no-repeat center center;
    background-size: cover;
    padding: 0 0 60px 0;
    position: relative;
}
.add .headline {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    text-align: center;
    padding: 20px 0;
    border: 2px solid transparent;
    background: linear-gradient(#000, #000) padding-box,
                linear-gradient(90deg, #1be7f5 0%, #2483f8 100%) border-box;
}
/* kazari-left (左飾り) */
.add .headline::before {
    content: '';
    flex-shrink: 0;
    width: 100px;
    height: 100px;
    background: url('../images/kazari-left.png') no-repeat center center;
    background-size: contain;
}
/* kazari-right (右飾り) */
.add .headline::after {
    content: '';
    flex-shrink: 0;
    width: 100px;
    height: 100px;
    background: url('../images/kazari-right.png') no-repeat center center;
    background-size: contain;
}
.add .headline h1 {
    font-size: 32px;
    font-weight: 800;
    background: linear-gradient(90deg, #1be7f5 0%, #2483f8 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.add h2 {
    font-size: 28px;
    font-weight: 800;
    text-align: center;
    margin: 40px 0 20px 0;
}

.add .img {
    margin: 40px auto;
    text-align: center;
}
.add .img img {
    width: 960px;
    margin: 0 auto;
    border: 2px solid transparent;
    background: linear-gradient(#fff, #fff) padding-box,
                linear-gradient(90deg, #1be7f5 0%, #2483f8 100%) border-box;
}

.add .text {
    margin-top: 20px;
    text-align: center;
}

.add .text p {
    font-size: 18px;
    font-weight: 300;
}
.add .text p b {
    font-weight: 700;
}
/* sec01 レスポンシブ */
@media screen and (max-width: 768px) {
.add {
        padding: 0 0 40px 0;
        background: #fff url('../images/bg_sp.png') no-repeat center center;
        background-size: cover;
    }
.add .headline {
        gap: 5px;
        padding: 20px 0;
    }
    .add .headline::before,
.add .headline::after {
        width: 40px;
        height: 60px;
    }
.add .headline h1 {
        font-size: 18px;
    }

.add h2 {
        font-size: 18px;
        margin: 20px 0 10px;
    }

.add .img {
        margin: 20px auto;
        text-align: center;
    }
.add .img img {
        width: 90%;
        margin: 0 auto;
    }
.add .text {
        text-align: left;
    }
    
.add .text p {
        font-size: 16px;
        font-weight: 300;
    }
}

@media screen and (max-width: 480px) {
}

/* sec01
---------------------------------------*/
.sec01 {
    background: #fff;
    padding: 70px 0 80px;
    position: relative;
}

.sec01 h1 {
    font-size: 48px;
    font-weight: 800;
    text-align: center;
    color: #111;
    margin-bottom: 40px;
}
.sec01 h1 .pink {
    color: #F70B78;
}
/* 「なんとなく」の上にドット圏点 */
.sec01 h1 .emphasis {
    display: inline-block;
    text-emphasis: dot #F70B78;
    -webkit-text-emphasis: dot #F70B78;
    text-emphasis-position: over;
    -webkit-text-emphasis-position: over;
}

.sec01 .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

/* チェックリストボックス（罫線ノート風） */
.sec01 .box {
    background: #fff;
    border: 15px solid #6A6A6A;
    padding: 10px 20px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
    background-position: 0 32px;
    margin: 60px auto;
}

.sec01 .box ul {
    background: url('../images/hougan.png') repeat center;
    list-style: none;
    padding: 30px 40px;
    margin: 0;
}

.sec01 .box ul li {
    position: relative;
    padding: 0 10px 30px 50px;
    font-size: 28px;
    font-weight: 600;
    color: #1a1a1a;
}

.sec01 .box ul li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 30%;
    transform: translateY(-50%);
    width: 35px;
    height: 35px;
    background: url("../images/check01.png") no-repeat center center;
    background-size: contain;
}

/* ボックス下のキャッチコピー */
.sec01 .text {
    margin: 40px auto 0;
    text-align: center;
}

.sec01 .text p {
    font-size: 28px;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0;
}

.sec01 .text p + p {
    margin-top: 22px;
}

.sec01 .text p.pink {
    color: #F70B78;
    font-size: 36px;
    font-weight: 800;
    letter-spacing: 0.02em;
}

/* sec01 レスポンシブ */
@media screen and (max-width: 768px) {
.sec01 {
        padding: 50px 0 60px;
    }

.sec01 h1 {
        font-size: 22px;
        margin-bottom: 26px;
    }

    /* 「なんとなく」を独立行に */
.sec01 h1 .pink {
        display: block;
        margin: 6px 0 4px;
        font-size: 28px;
    }

.sec01 .inner {
        width: 90%;
        max-width: 90%;
    }

    /* ボックス：PC版を踏襲しつつサイズだけSP用に */
.sec01 .box {
        padding: 10px 14px;
        margin: 30px auto;
        border: 10px solid #6A6A6A
    }

.sec01 .box ul {
        padding: 18px 0;
    }

.sec01 .box ul li {
        font-size: 16px;
        padding: 9px 0 9px 36px;
        line-height: 1.6;
    }

.sec01 .box ul li::before {
        width: 22px;
        height: 22px;
        left: 0;
        top: 18px;
        transform: none;
    }

.sec01 .text {
        margin-top: 28px;
    }

.sec01 .text p {
        font-size: 14px;
    }

.sec01 .text p + p {
        margin-top: 10px;
    }

.sec01 .text p.pink {
        font-size: 17px;
    }
}

@media screen and (max-width: 480px) {
.sec01 h1 {
        font-size: 24px;
        line-height: 1;
    }

.sec01 h1 .pink {
        font-size: 36px;
        line-height: 1.4;
    }

.sec01 h1 br {
        display: none;
    }

.sec01 .text p{
        font-size: 18px;
    }
.sec01 .text p.pink {
        font-size: 24px;
    }
}

/* sec02
---------------------------------------*/

/* sec02 */
.sec02 {
    padding: 0;
}

/* sec02a：濃紺背景＋白カードボックス */
.sec02a {
    background: linear-gradient(180deg, #102D60 0%, #000000 100%);
    padding: 80px 0;
    text-align: center;
    position: relative;
}

/* sec02a → sec02b への誘導三角（全幅） */
.sec02a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -50px;
    width: 100%;
    height: 50px;
    background: #000000;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    z-index: 2;
}

/* h1：黒い帯見出し */
.sec02a > h1 {
    color: #fff;
    font-size: 48px;
    font-weight: 800;
    letter-spacing: 0.04em;
    margin: 0 0 22px;
}

/* リード文 */
.sec02a > .text {
    margin-bottom: 38px;
}

.sec02a > .text p {
    font-size: 24px;
    color: #fff;
    margin: 0;
}

/* 中央の白い大ボックス */
.sec02a .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

.sec02a .box {
    background: #fff;
    padding: 40px 40px 50px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.25);
}

/* 白ボックス内の見出し */
.sec02a .box h2 {
    font-size: 48px;
    font-weight: 800;
    color: #1a1a1a;
    text-align: center;
    margin: 0 0 40px;
}

.sec02a .box h2 .pink {
    color: #F70B78;
}

/* 各落とし穴カード */
.sec02a .box dl {
    border: 2px solid #1f3a8a;
    margin-bottom: 20px;
    background: #fff;
    overflow: hidden;
}

.sec02a .box dl:last-child {
    margin-bottom: 0;
}

/* dt：上段（紺背景）に黄色ラベル + 白文字タイトル */
.sec02a .box dt {
    display: flex;
    align-items: center;
    gap: 4px;
    background: #0C3782;
    color: #fff;
    font-size: 24px;
    font-weight: 800;
    padding: 0 16px 0 12px;
    min-height: 60px;
    text-align: left;
}

/* 落とし穴①ラベル */
.sec02a .box dt span.label {
    background: #fff000;
    color: #000;
    font-size: 16px;
    font-weight: 800;
    padding: 8px 14px;
    margin-right: 8px;
    white-space: nowrap;
    letter-spacing: 0.02em;
    flex-shrink: 0;
}

/* 説明文（下段） */
.sec02a .box dd {
    margin: 0;
    padding: 12px 18px 14px;
    font-size: 18px;
    color: #1f3a8a;
    background: #fff;
    text-align: left;
}

/* 旧 .text2（互換のため残す） */
.sec02a .text2 {
    text-align: center;
    position: relative;
    z-index: 1;
}

.sec02a .text2 p {
    font-size: 14px;
    color: #fff;
}



/* sec02b */
.sec02b {
    background: #fff;
    padding: 110px 0 80px;
    text-align: center;
}

.sec02b > h1 {
    font-size: 48px;
    font-weight: 800;
    color: #000;
    text-align: center;
    margin: 0 0 40px;
}

.sec02b > h1 .pink {
    color: #F70B78;
}

.sec02b .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

.sec02b .flex {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}

/* 左：チェックリスト */
.sec02b .left {
    flex: 1;
    min-width: 0;
}

.sec02b .left ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sec02b .left ul li {
    position: relative;
    background: #fff;
    border: 5px solid #559BD2;
    border-radius: 14px;
    padding: 16px 32px 16px 64px;
    font-size: 24px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 14px;
    text-align: left;
}

.sec02b .left ul li:last-child {
    margin-bottom: 0;
}

.sec02b .left ul li::before {
    content: "";
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    background: url("../images/sec02-icon.png") no-repeat center center;
    background-size: contain;
}

/* 吹き出しの尻尾（右下に大小2つの丸） */
.sec02b .left ul li::after {
    content: "";
    position: absolute;
    width: 32px;
    height: 24px;
    bottom: -10px;
    background:
        radial-gradient(circle 7px at 7px 7px, #559BD2 0 7px, transparent 7px) no-repeat,
        radial-gradient(circle 4px at 20px 12px, #559BD2 0 4px, transparent 4px) no-repeat;
    background-color: transparent;
    border-radius: 0;
    pointer-events: none;
}

/* 各 li の吹き出しテール位置：徐々に右にずらしてジグザグに */
.sec02b .left ul li:nth-child(1)::after {
    top: 50px;
    right: -32px;
}

.sec02b .left ul li:nth-child(2)::after {
    top: 50px;
    right: -32px;
}

.sec02b .left ul li:nth-child(3)::after {
    top: 50px;
    right: -32px;
}

.sec02b .left ul li:nth-child(4)::after {
    top: 50px;
    right: -32px;
}

/* 右：イラスト */
.sec02b .right {
    flex-shrink: 0;
    width: 260px;
    text-align: center;
}

.sec02b .right img {
    max-width: 100%;
    height: auto;
    display: block;
    margin: 100px auto 0;
}

/* 下のキャッチコピー */
.sec02b .text {
    margin-top: 36px;
    text-align: center;
}

.sec02b .text p {
    font-size: 32px;
    font-weight: 800;
    color: #1a1a1a;
    margin: 0;
}

/* sec02 レスポンシブ */
@media screen and (max-width: 768px) {

.sec02 {
        padding: 0;
    }

.sec02a {
        padding: 40px 0;
    }

    /* SP：誘導三角を小さく（高さのみ） */
.sec02a::after {
        bottom: -30px;
        height: 30px;
    }

.sec02a > h1 {
        font-size: 24px;
        margin-bottom: 10px;
    }

.sec02a > .text {
        margin-bottom: 26px;
        padding: 0 4%;
    }

.sec02a > .text p {
        font-size: 18px;
        text-align: center;
    }

.sec02a .inner {
        width: 92%;
        max-width: 92%;
    }

.sec02a .box {
        padding: 16px 14px 18px;
        background: #fff;
        box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
    }

    /* SPでは見出しは非表示 */
.sec02a .box h2 {
        display: none;
    }

    /* カードを縦並び（dt 紺色エリア / dd 説明白エリア） */
.sec02a .box dl {
        display: block;
        background: none;
        border: 2px solid #0C3782;
        overflow: visible;
        margin-top: 18px;
        margin-bottom: 25px;
        position: relative;
    }

    /* dt：紺背景に「ラベル(span)」上 + メインタイトル下を縦並び・中央 */
.sec02a .box dt {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 6px;
        background: #0C3782;
        color: #fff;
        font-size: 20px;
        font-weight: 800;
        text-align: center;
        padding: 10px 14px 12px;
        margin: 0;
        line-height: 1.45;
        min-height: 0;
        width: auto;
        border-radius: 0;
        white-space: normal;
        position: relative;
    }

    /* 落とし穴①ラベル（span）：黄色ピルを上にはみ出させて重ねる */
.sec02a .box dt span.label {
        width: 50%;
        background: #fff000;
        color: #000;
        font-size: 16px;
        font-weight: 800;
        border-radius: 999px;
        text-align: center;
        padding: 5px 0;
        margin: -25px auto 0;
        letter-spacing: 0.02em;
        white-space: nowrap;
        line-height: 1.2;
        position: relative;
        z-index: 10;
    }
    .sec02a .box dt span.note{
        font-size: 12px;
        color: #fff;
    }

    /* 説明文：白背景・紺文字・中央 */
.sec02a .box dd {
        background: #fff;
        color: #0C3782;
        font-size: 16px;
        font-weight: 600;
        text-align: left;
        padding: 12px 14px 14px;
        margin: 0;
        line-height: 1.6;
    }

.sec02a .text2 p {
        font-size: 12px;
        color: #fff;
    }

.sec02b {
        padding: 70px 0 30px;
    }

.sec02b > h1 {
        font-size: 24px;
        margin-bottom: 28px;
    }

.sec02b > h1 .pink {
        background-size: 100% 3px;
        padding-bottom: 4px;
    }

.sec02b .inner {
        width: 90%;
        max-width: 90%;
    }

.sec02b .flex {
        flex-direction: column;
        align-items: stretch;
        gap: 24px;
    }

.sec02b .left {
        order: 1;
        max-width: 100%;
        position: relative;
    }

    /* 思考吹き出しのテール：大きい泡 */
.sec02b .left::after {
        content: "";
        position: absolute;
        right: 8%;
        bottom: -9px;
        width: 14px;
        height: 14px;
        background: #559BD2;
        border-radius: 50%;
        box-sizing: border-box;
    }

    /* 思考吹き出しのテール：小さい泡 */
.sec02b .left::before {
        content: "";
        position: absolute;
        right: 10%;
        bottom: -20px;
        width: 9px;
        height: 9px;
        background: #559BD2;
        border-radius: 50%;
        box-sizing: border-box;
        z-index: 1;
    }

.sec02b .left ul li {
        font-size: 18px;
        font-weight: 700;
        line-height: 1.5;
        padding: 14px 0 14px 24px;
        margin-bottom: 14px;
        border-radius: 20px;
        text-align: center;
    }

.sec02b .left ul li::before {
        left: 10px;
        width: 28px;
        height: 28px;
    }

    /* SPでは右のドットは非表示 */
.sec02b .left ul li::after {
        display: none;
    }

.sec02b .right {
        order: 2;
        width: 60%;
        max-width: 240px;
        margin: 0 auto;
    }

.sec02b .right img {
        margin: 0 auto;
    }

.sec02b .text {
        margin-top: 26px;
    }

.sec02b .text p {
        font-size: 18px;
    }
}

@media screen and (max-width: 480px) {
}






/* sec03
---------------------------------------*/
.sec03 {
    background: #050505 url("../images/sec03-bg.png") no-repeat center center;
    background-size: cover;
    padding: 70px 0 80px;
    position: relative;
    text-align: center;
    overflow: hidden;
}

/* 背景の上に黒の半透明レイヤーを重ねて文字を読みやすく */
.sec03::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    pointer-events: none;
    z-index: 0;
}

.sec03 > * {
    position: relative;
    z-index: 1;
}

/* 見出し */
.sec03 h1 {
    font-family: "Hiragino Mincho ProN", "Yu Mincho", "游明朝", serif;
    font-size: 56px;
    font-weight: 800;
    color: #fff;
    text-align: center;
    margin: 0 0 18px;
    letter-spacing: 0.04em;
}

/* リード文（答えはシンプルです。） */
.sec03 .text {
    text-align: center;
    margin: 0 0 32px;
}

.sec03 .text p {
    font-size: 42px;
    font-weight: 700;
    color: #fff;
    margin: 0;
}

/* メインのコピー入りボックス */
.sec03 .box {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
    background: #fff;
    padding: 28px 20px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.35);
}

.sec03 .box-inner {
    text-align: center;
}

.sec03 .box-inner p {
    font-size: 36px;
    font-weight: 800;
    color: #1a1a1a;
    margin: 0;
    letter-spacing: 0.02em;
}

/* 黄色マーカー（common.cssの .marker をそのまま利用） */
.sec03 .box-inner .marker {
    background: linear-gradient(transparent 55%, #fff000 55%);
    padding: 0 2px;
}

/* AIです！の強調 */
.sec03 .box-inner .pink {
    font-size: 48px;
    color: #F70B78;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.sec03 {
        padding: 50px 0 60px;
    }

.sec03 h1 {
        font-size: 24px;
        margin-bottom: 10px;
    }

.sec03 .text {
        margin-bottom: 18px;
    }

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

.sec03 .box {
        width: 90%;
        max-width: 90%;
        padding: 20px 0;
    }

.sec03 .box-inner p {
        font-size: 18px;
    }

    .sec03 .box-inner p .pink{
            font-size: 24px;
        }
}

@media screen and (max-width: 480px) {
.sec03 h1 {
        font-size: 24px;
    }

.sec03 .box-inner p {
        font-size: 18px;
    }
}


/* sec04
---------------------------------------*/
.sec04 {
    background: #fff;
    padding: 70px 0 80px;
    text-align: center;
}

.sec04 .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

/* 見出し＋ロボットイラスト */
.sec04 .heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
}

.sec04 h1 {
    flex: 1;
    font-size: 48px;
    font-weight: 800;
    color: #1a1a1a;
    text-align: left;
    margin: 0;
}

/* 「AI」のピンク巨大装飾 */
.sec04 h1 .ai {
    display: inline-block;
    color: #F70B78;
    font-size: 80px;
    font-family: "Helvetica Neue", Arial, sans-serif;
    font-weight: 800;
    letter-spacing: -0.02em;
    vertical-align: -6px;
}

.sec04 .heading .hero {
    flex-shrink: 0;
    width: 280px;
    height: auto;
    display: block;
}

/* リストボックス（ピンク太枠＋方眼背景） */
.sec04 .box {
    background: #fff;
    border: 15px solid #F70B78;
    padding: 10px 20px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
    margin: 0 auto;
}

.sec04 .box ul {
    background: url('../images/hougan.png') repeat center;
    list-style: none;
    padding: 30px 40px;
    margin: 0;
}

.sec04 .box ul li {
    position: relative;
    padding: 0 4px 0 28px;
    font-size: 28px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 30px;
    text-align: left;
}

.sec04 .box ul li:last-child {
    margin-bottom: 0;
}

.sec04 .box ul li::before {
    content: "";
    position: absolute;
    left: -10px;
    top: 0.2em;
    width: 30px;
    height: 30px;
    background: url("../images/sec04-icon.png") no-repeat center center;
    background-size: contain;
}

/* （補足）の小さい注釈 */
.sec04 .box ul li .note {
    font-size: 18px;
    font-weight: 500;
    color: #555;
    margin-left: 6px;
}

/* 締めキャッチコピー */
.sec04 .text {
    margin-top: 36px;
    text-align: center;
}

.sec04 .text p {
    font-size: 32px;
    color: #1a1a1a;
    margin: 0;
}

.sec04 .text p .strong {
    font-weight: 800;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.sec04 {
        padding: 40px 0;
    }

.sec04 .inner {
        width: 92%;
        max-width: 92%;
    }

    /* heading：見出し（黒帯）を上、ロボット画像を下に縦並び */
.sec04 .heading {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

.sec04 h1 {
        width: 100%;
        font-size: 24px;
        text-align: center;
        line-height: 1.5;
        margin: 0;
    }

.sec04 h1 > .ai {
        font-size: 32px;
        letter-spacing: 0;
        vertical-align: 0;
    }

    .sec04 .heading .hero {
        max-width: 180px;
        width: 180px;
        margin-bottom: 0;
    }

.sec04 .box {
        border-width: 8px;
        padding: 6px 10px;
    }

.sec04 .box ul {
        padding: 20px 16px;
    }

.sec04 .box ul li {
        font-size: 18px;
        padding: 0 4px 0 18px;
        margin-bottom: 10px;
    }

.sec04 .box ul li::before {
        width: 18px;
        height: 18px;
        top: 0.3em;
    }

.sec04 .box ul li .note {
        display: inline;
        font-size: 12px;
        margin-left: 0;
    }

.sec04 .text {
        margin-top: 28px;
    }

.sec04 .text p {
        font-size: 18px;
    }

.sec04 .text p .strong {
        font-size: 18px;
    }
}

/* sec05
---------------------------------------*/
.sec05 {
    background: #050505 url("../images/sec05-bg.png") no-repeat center center;
    background-size: cover;
    padding: 70px 0 100px;
    position: relative;
    text-align: center;
    overflow: hidden;
}

/* 背景上の半透明黒オーバーレイ（読みやすさ用） */
.sec05::before {
    content: "";
    position: absolute;
    inset: 24px 0;
    background: rgba(0, 0, 0, 0.55);
    pointer-events: none;
    z-index: 0;
}

/* 上下の警告ストライプ帯 */
.sec05 > .stripe-top,
.sec05 > .stripe-bottom,
.sec05::after {
    pointer-events: none;
}

.sec05::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 24px;
    background: repeating-linear-gradient(
        -45deg,
        #fff 0,
        #fff 14px,
        #000 14px,
        #000 28px
    );
    z-index: 2;
}

/* 上のストライプ帯（::before に追加できないため、独立した装飾レイヤーで描画） */
.sec05 {
    /* 上下にストライプを敷く方式：背景画像 + 線形グラデで二重に */
    background:
        repeating-linear-gradient(-45deg, #fff 0, #fff 14px, #000 14px, #000 28px) top / 100% 24px no-repeat,
        repeating-linear-gradient(-45deg, #fff 0, #fff 14px, #000 14px, #000 28px) bottom / 100% 24px no-repeat,
        #050505 url("../images/sec05-bg.png") no-repeat center center;
    background-size: 100% 24px, 100% 24px, cover;
}

/* sec05::after の下ストライプは backgroundで処理するためリセット */
.sec05::after {
    content: none;
}

.sec05 > * {
    position: relative;
    z-index: 1;
}

/* 見出し */
.sec05 h1 {
    font-size: 56px;
    color: #fff;
    text-align: center;
    margin: 30px 0 20px;
    letter-spacing: 0.04em;
}
.sec05 h1 span.mincho {}

/* ピンク文字 + 黄色マーカー強調 */
.sec05 h1 .emphasis,
.sec05 .box-inner .emphasis {
    color: #F70B78;
    padding: 0 4px;
}

.sec05 h1 .emphasis {
    font-size: 56px;
}

/* リード「それは——」 */
.sec05 .text {
    text-align: center;
    margin: 0 0 28px;
}

.sec05 .text p {
    font-size: 42px;
    color: #fff;
    font-weight: 800;
    margin: 0;
    letter-spacing: 0.04em;
}

/* 白いコピー入りボックス */
.sec05 .box {
    width: 880px;
    max-width: 92%;
    margin: 0 auto;
    background: #fff;
    padding: 30px 24px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.sec05 .box-inner {
    text-align: center;
}

.sec05 .box-inner p {
    font-size: 42px;
    font-weight: 800;
    color: #1a1a1a;
    margin: 0;
    letter-spacing: 0.02em;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.sec05 {
        padding: 50px 0 60px;
        background-size: 100% 18px, 100% 18px, cover;
    }

.sec05::before {
        inset: 18px 0;
    }

.sec05 h1 {
        font-size: 24px;
        margin: 20px 0 14px;
    }

.sec05 h1 .emphasis {
        font-size: 24px;
    }

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

.sec05 .text {
        margin-bottom: 22px;
    }

.sec05 .box {
        padding: 20px 0;
    }

.sec05 .box-inner p {
        font-size: 24px;
    }
    .sec05 .box-inner p .emphasis {
        font-size: 24px;
        display: block;
    }
}


/* sec06
---------------------------------------*/
.sec06 {
    background: #fff;
    padding: 70px 0 100px;
    text-align: left;
    position: relative;
}

/* sec06 → sec07 への誘導三角（全幅） */
.sec06::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -50px;
    width: 100%;
    height: 50px;
    background: #fff;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    z-index: 2;
}

.sec06 .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

/* 見出し＋スマホイラスト */
.sec06 .heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
}

.sec06 .heading h1 {
    flex: 1;
    font-size: 48px;
    font-weight: 800;
    color: #1a1a1a;
    margin: 0;
    text-align: left;
}

.sec06 .heading .hero {
    flex-shrink: 0;
    width: 250px;
    height: auto;
    display: block;
}

/* リストボックス（水色枠＋方眼背景） */
.sec06 .box {
    background: #fff;
    border: 15px solid #2eb6ff;
    padding: 10px 20px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
    margin: 0 auto;
}

.sec06 .box ul {
    background: url('../images/hougan.png') repeat center;
    list-style: none;
    padding: 30px 40px;
    margin: 0;
}

.sec06 .box ul li {
    position: relative;
    padding: 0 4px 0 30px;
    font-size: 28px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 20px;
}

.sec06 .box ul li:last-child {
    margin-bottom: 0;
}

/* ×（バツ）マーク：CSSで2本の線を交差 */
.sec06 .box ul li::before,
.sec06 .box ul li::after {
    content: "";
    position: absolute;
    left: -10px;
    top: 0.65em;
    width: 30px;
    height: 8px;
    background: #2eb6ff;
    border-radius: 1px;
}

.sec06 .box ul li::before {
    transform: rotate(45deg);
}

.sec06 .box ul li::after {
    transform: rotate(-45deg);
}

/* 補足カッコ書き */
.sec06 .box ul li .note {
    font-size: 18px;
    font-weight: 500;
    color: #666;
    margin-left: 4px;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.sec06 {
        padding: 40px 0;
    }

    /* SP：誘導三角を小さく（高さのみ） */
.sec06::after {
        bottom: -30px;
        height: 30px;
    }

    /* h1 → box → hero の順に縦並び */
.sec06 .inner {
        width: 92%;
        max-width: 92%;
        display: flex;
        flex-direction: column;
        gap: 24px;
    }

    /* heading の枠を解除して子を inner の直接の子として扱う */
.sec06 .heading {
        display: contents;
    }

    /* 見出し：黒帯ボックス（sec04 を踏襲、枠は水色） */
.sec06 .heading h1 {
        font-size: 24px;
        text-align: center;
        line-height: 1.5;
    }

    /* ボックス */
.sec06 .box {
        order: 2;
        border-width: 8px;
        padding: 6px 10px;
        position: relative;
    }

    /* ボックス下部の三角シェイプ（吹き出しの尻尾） */
.sec06 .box::after {
        content: "";
        position: absolute;
        left: 50%;
        bottom: -20px;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 20px solid transparent;
        border-right: 20px solid transparent;
        border-top: 20px solid #2eb6ff;
    }

    /* イラストは box の下に */
.sec06 .heading .hero {
        order: 3;
        width: 60%;
        max-width: 160px;
        margin: 0 auto;
    }

.sec06 .box ul {
        padding: 20px 16px;
    }

.sec06 .box ul li {
        font-size: 18px;
        padding: 0 4px 0 25px;
        margin-bottom: 10px;
    }

    .sec06 .box ul li::before,
.sec06 .box ul li::after {
        width: 24px;
        height: 4px;
        top: 0.55em;
    }

.sec06 .box ul li .note {
        display: block;
        font-size: 12px;
        margin-left: 0;
        margin-top: 2px;
    }
}


/* sec07
---------------------------------------*/
.sec07 {
    background: #f5f5f5;
    padding: 70px 0 80px;
    text-align: left;
}

.sec07 .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

/* 見出し＋ロボットイラスト */
.sec07 .heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
}

.sec07 .heading h1 {
    flex: 1;
    font-size: 48px;
    font-weight: 800;
    color: #1a1a1a;
    text-align: left;
    margin: 0;
}
.sec07 .heading .pink {
    color: #F70B78;
}
.sec07 .heading .hero {
    margin-top: 40px;
    flex-shrink: 0;
    width: 330px;
    height: auto;
    display: block;
}

/* リストボックス（ピンク太枠＋方眼背景） */
.sec07 .box {
    background: #fff;
    border: 15px solid #F70B78;
    padding: 10px 20px;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.05);
    margin: 0 auto;
}

.sec07 .box ul {
    background: url('../images/hougan.png') repeat center;
    list-style: none;
    padding: 30px 40px;
    margin: 0;
}

.sec07 .box ul li {
    position: relative;
    padding: 0 4px 0 28px;
    font-size: 28px;
    font-weight: 700;
    color: #1a1a1a;
    margin-bottom: 30px;
    text-align: left;
}

.sec07 .box ul li:last-child {
    margin-bottom: 0;
}

.sec07 .box ul li::before {
    content: "";
    position: absolute;
    left: -10px;
    top: 0.2em;
    width: 30px;
    height: 30px;
    background: url("../images/sec04-icon.png") no-repeat center center;
    background-size: contain;
}

/* （補足）の小さい注釈 */
.sec07 .box ul li .note {
    font-size: 18px;
    font-weight: 500;
    color: #555;
    margin-left: 6px;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.sec07 {
        padding: 80px 0 40px;
    }

.sec07 .inner {
        width: 92%;
        max-width: 92%;
    }

    /* heading：見出し上、画像下の縦並び（sec04 踏襲） */
.sec07 .heading {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

.sec07 .heading h1 {
        width: 100%;
        font-size: 24px;
        text-align: center;
        line-height: 1.5;
        margin: 0;
    }

.sec07 .heading .hero {
        max-width: 180px;
        width: 180px;
        margin-top: 0;
    }

.sec07 .box {
        border-width: 8px;
        padding: 10px 10px;
    }

.sec07 .box ul {
        padding: 20px 16px;
    }

.sec07 .box ul li {
        font-size: 18px;
        padding: 0 4px 0 18px;
        margin-bottom: 20px;
    }

.sec07 .box ul li::before {
        width: 24px;
        height: 24px;
        left: -16px;
        top: 0em;
    }

.sec07 .box ul li .note {
        display: inline;
        font-size: 12px;
        margin-left: 0;
    }
}

@media screen and (max-width: 480px) {

.sec07 .heading .hero {
        max-width: 180px;
        width: 180px;
    }
}

/* sec08（4つの特典）
---------------------------------------*/
.sec08 {
    background: #fff;
    padding: 0 0 80px;
    text-align: center;
}

/* ピンクのフルワイド見出しバー */
.sec08 > h1 {
    background: #F70B78;
    color: #fff;
    font-size: 60px;
    font-weight: 800;
    padding: 42px 0;
    margin: 0 0 50px;
    text-align: center;
    letter-spacing: 0.04em;
}

/* リード文 */
.sec08 > h2 {
    font-size: 42px;
    color: #1a1a1a;
    text-align: center;
    margin: 0 0 28px;
    letter-spacing: 0.02em;
}

.sec08 > h2 .pink {
    color: #F70B78;
}

/* 下向き矢印（arrow.png） */
.sec08 > .arrow {
    width: 56px;
    height: 56px;
    margin: 0 auto;
    background: url("../images/arrow.png") no-repeat center center;
    background-size: contain;
}

.sec08 .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

/* 各特典ブロック（区切り線のみ） */
.sec08 .benefit {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 40px;
    padding: 60px 0;
    border-bottom: 1px solid #e5e5e5;
    text-align: left;
}

.sec08 .benefit:last-child {
    border-bottom: none;
}

.sec08 .benefit .left {
    flex: 1;
    min-width: 0;
}

.sec08 .benefit .right {
    flex-shrink: 0;
    width: 380px;
    align-self: center;
}

.sec08 .benefit .right img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* 特典XX ラベル（ピンクの pill） */
.sec08 .benefit h3 {
    display: inline-block;
    background: linear-gradient(90deg, #F70B78 0%, #FF73B4 100%);
    color: #fff;
    font-size: 24px;
    font-weight: 600;
    padding: 9px 22px;
    letter-spacing: 0.2em;
    border-radius: 999px;
    margin: 0 0 18px;
}

/* タイトル（黒・太字） */
.sec08 .benefit h4 {
    font-size: 32px;
    color: #F70B78;
    margin: 0 0 14px;
}

/* サブタイトル */
.sec08 .benefit h5 {
    font-size: 24px;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0 0 16px;
}

/* 説明文 */
.sec08 .benefit .text {
    margin: 0 0 22px;
}

.sec08 .benefit .text p {
    font-size: 22px;
    color: #555;
    margin: 0;
}

/* チェックリスト（薄ピンク帯 pill） */
.sec08 .benefit ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sec08 .benefit ul li {
    position: relative;
    background: #FFF4F9;
    color: #1a1a1a;
    font-size: 20px;
    font-weight: 700;
    padding: 15px 18px 15px 56px;
    border-radius: 999px;
    margin-bottom: 10px;
}

.sec08 .benefit ul li:last-child {
    margin-bottom: 0;
}

.sec08 .benefit ul li::before {
    content: "";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    background: url("../images/benefit-check.png") no-repeat center center;
    background-size: contain;
}

/* 補足注釈（特典02 のテキスト下 p） */
.sec08 .benefit .left > p {
    font-size: 18px;
    color: #888;
    margin: 14px 0 0;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.sec08 {
        padding: 0;
    }

.sec08 > h1 {
        font-size: 24px;
        padding: 20px 0;
        margin-bottom: 28px;
    }

.sec08 > h2 {
        font-size: 24px;
        margin-bottom: 18px;
    }

.sec08 > .arrow {
        width: 44px;
        height: 44px;
    }

.sec08 .inner {
        width: 92%;
        max-width: 92%;
    }

.sec08 .benefit {
        flex-direction: column;
        gap: 20px;
        padding: 10px 0 30px;
    }

.sec08 .benefit .right {
        order: 2;
        width: 100%;
        max-width: 100%;
        margin: 0 auto;
    }

.sec08 .benefit .left {
        order: 1;
        width: 100%;
    }

    /* 特典XX ラベル：黒背景の長方形 */
.sec08 .benefit h3 {
    width: 100px;
        color: #fff;
        font-size: 16px;
        font-weight: 600;
        padding: 5px 0;
        margin: 0 0 14px;
        text-align: center;
    }

    /* タイトル：ピンク文字＋ピンクの下線 */
.sec08 .benefit h4 {
        font-size: 24px;
    }

.sec08 .benefit h5 {
        font-size: 18px;
    }

.sec08 .benefit .text p {
        font-size: 16px;
    }

.sec08 .benefit ul li {
        font-size: 14px;
        font-weight: 600;
        padding: 10px 0 10px 38px;
    }

.sec08 .benefit ul li::before {
        width: 15px;
        height: 15px;
        left: 15px;
    }
    .sec08 .benefit .right img{
        width: 80%;
        margin: 0 auto;
    }

    /* 画像下の注釈：.right の中（imgの直後）に配置 */
.sec08 .benefit .right p.sp {
        font-size: 12px;
        margin: 10px 0 0;
    }
}


/* company（10周年・会社概要）
---------------------------------------*/
.company {
    background: #f5f5f5;
    padding: 90px 0;
    text-align: center;
}

.company .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

.company h1 {
    font-size: 32px;
    font-weight: 800;
    color: #1a1a1a;
    text-align: center;
    margin: 0 0 32px;
}

.company h1 .pink {
    color: #F70B78;
}

.company h2 {
    font-size: 32px;
    color: #1a1a1a;
    text-align: center;
    margin: 0 0 26px;
}

.company .event-img {
    margin: 60px 0;
    text-align: center;
}

.company .event-img img {
    max-width: 100%;
    height: auto;
    margin: 0 auto;
}

.company .text p {
    font-size: 22px;
    color: #1a1a1a;
    margin: 0 0 22px;
}

.company .text p:last-child {
    margin: 0;
}

.company .text .bold {
    font-weight: 800;
}

/* 会社概要セクション（白背景） */
.company-profile {
    background: #fff;
    padding: 70px 0 80px;
    text-align: center;
}

.company-profile .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

.company-profile .profile h3 {
    font-size: 36px;
    font-weight: 800;
    color: #1a1a1a;
    text-align: center;
    margin: 0 0 32px;
}

.company-profile .profile .info {
    width: 100%;
    border-collapse: collapse;
    margin: 0 0 28px;
    background: #fff;
}

.company-profile .profile .info th,
.company-profile .profile .info td {
    text-align: left;
    padding: 14px 20px;
    font-size: 18px;
    border: 2px solid #fff;
    vertical-align: middle;
}

.company-profile .profile .info th {
    background: #1f3a8a;
    color: #fff;
    width: 130px;
    font-weight: 700;
    text-align: center;
    border-color: #1f3a8a;
}

.company-profile .profile .info td {
    background: #EEF4FF;
    color: #1a1a1a;
}

.company-profile .profile .desc {
    text-align: left;
    margin: 0 0 32px;
}

.company-profile .profile .desc p {
    font-size: 18px;
    color: #1a1a1a;
    margin: 0 0 14px;
}

.company-profile .profile .desc p:last-child {
    margin: 0;
}

/* 政府機関ロゴ */
.company-profile .profile .logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    flex-wrap: wrap;
}

.company-profile .profile .logos img {
    height: 80px;
    width: auto;
    display: block;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.company {
        padding: 40px 0 5px;
    }

.company .inner {
        width: 92%;
        max-width: 92%;
    }

.company h1 {
        font-size: 18px;
        margin-bottom: 22px;
    }

.company h2 {
        font-size: 18px;
        margin-bottom: 18px;
    }

.company .event-img {
        margin: 40px 0;
    }

.company .text {
        margin-bottom: 40px;
    }

.company .text p {
        font-size: 16px;
        text-align: left;
        margin-bottom: 16px;
    }

.company .text p br {
        display: none;
    }

.company-profile {
        padding: 50px 0 60px;
    }

.company-profile .inner {
        width: 92%;
        max-width: 92%;
    }

.company-profile .profile h3 {
        font-size: 22px;
        margin-bottom: 18px;
    }

    /* SPでは th/td を縦並びの帯に */
.company-profile .profile .info,
.company-profile .profile .info tbody,
.company-profile .profile .info tr,
.company-profile .profile .info th,
.company-profile .profile .info td {
        display: block;
        width: 100%;
    }

.company-profile .profile .info tr {
        margin-bottom: 0;
    }

    .company-profile .profile .info th,
.company-profile .profile .info td {
        font-size: 14px;
        border: none;
    }

.company-profile .profile .info th {
        background: #102D60;
        color: #fff;
        text-align: center;
        font-weight: 700;
        padding: 12px 0;
    }

.company-profile .profile .info td {
        background: #EEF4FF;
        text-align: center;
        padding: 16px 0;
    }

.company-profile .profile .desc {
        margin-bottom: 24px;
    }

.company-profile .profile .desc p {
        font-size: 14px;
        margin-bottom: 0;
    }

.company-profile .profile .logos {
        gap: 20px;
    }

.company-profile .profile .logos img {
        height: 48px;
    }
}



/* footer
---------------------------------------*/
.site-footer {
    background: #000;
    color: #fff;
    padding: 36px 0 28px;
    text-align: center;
}

.site-footer .inner {
    width: 1080px;
    max-width: 92%;
    margin: 0 auto;
}

/* メニュー */
.site-footer .menu {
    list-style: none;
    padding: 0;
    margin: 0 0 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 12px 36px;
}

.site-footer .menu li {
    font-size: 12px;
}

.site-footer .menu li a {
    color: #fff;
    text-decoration: none;
    transition: opacity 0.2s ease;
}

.site-footer .menu li a:hover {
    opacity: 0.7;
}

/* 住所・連絡先 */
.site-footer .info {
    margin: 0 0 26px;
}

.site-footer .info p {
    font-size: 12px;
    color: #fff;
    margin: 0;
}

/* コピーライト */
.site-footer .copyright {
    font-size: 12px;
    color: #fff;
    margin: 0;
}

/* レスポンシブ */
@media screen and (max-width: 768px) {
.site-footer {
        padding: 28px 0 22px;
    }

.site-footer .inner {
        width: 90%;
        max-width: 90%;
    }

.site-footer .menu {
        gap: 8px 18px;
        margin-bottom: 22px;
        display: block;
        text-align: left;
    }

.site-footer .menu li {
        font-size: 12px;
        border-bottom: 1px dotted #333;
        padding: 15px 0;
    }

.site-footer .info {
        margin-bottom: 18px;
    }

.site-footer .info p {
        font-size: 12px;
        text-align: left;
    }

}

