/* タブレット対応 tablet */
@media (max-width: 1024px) {

    /*************************** 01. 枠組共通 ***********************/
    .tab-none {
        display: none;
    }

    /*************************** 02. header（ヘッダー） ***********************/
    /* Q HACK ヘッダー - タブレット */
    .qhack-header__top-inner {
        padding: 12px 16px;
    }
    .qhack-header__logo img {
        height: 50px;
    }
    .qhack-header__desc {
        font-size: 12px;
    }
    .qhack-header__nav {
        display: none;
    }
    /* タブレット版ではヘッダーCTAボタンを非表示 */
    .qhack-header__cta {
        display: none;
    }
    /* タブレット/SP時はヘッダーTop部分にグラデーションボーダーを追加 */
    .qhack-header__top {
        position: relative;
    }
    .qhack-header__top::after {
        content: '';
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        height: 2px;
        background: linear-gradient(90deg, #FF3D3B 0%, #B701F7 100%);
    }
    .qhack-cta-btn {
        width: 200px;
        padding: 10px 16px;
    }
    .qhack-cta-btn__sub {
        font-size: 11px;
    }
    .qhack-cta-btn__main {
        font-size: 13px;
    }
    .qhack-header__hamburger {
        display: flex;
        width: 18px;
        height: 13px;
        padding: 0;
    }
    .qhack-header__hamburger svg {
        width: 18px;
        height: 15px;
        flex-shrink: 0;
    }
    
    /* Q HACK モバイルメニュー - タブレット表示 */
    .qhack-mobile-menu {
        display: block;
    }
    #body_wrap {
        padding-top: 70px;
    }
    body.admin-bar #body_wrap {
        padding-top: 102px; /* 70px + 32px */
    }
    
    /* 既存SWELL用（非表示のため参考程度） */
    .-img .c-headLogo__link{
        padding:5px 0;
    }
    /* Q HACK 会社紹介セクション - タブレット */
    .qhack-intro {
        padding: 60px 20px 80px;
    }
    .qhack-intro__title-box {
        width: 100%;
        max-width: 700px;
        padding: 6px 20px;
    }
    .qhack-intro__title-sub {
        font-size: 24px;
    }
    .qhack-intro__title-main {
        font-size: 32px;
    }
    .qhack-intro__content {
        width: 100%;
        max-width: 700px;
    }
    .qhack-intro__content p {
        font-size: 18px;
        line-height: 32px;
    }
    .qhack-intro__content p br {
        display: none;
    }
    .qhack-intro__highlight {
        font-size: 22px;
        background-size: 100% 2px;
        padding-bottom: 2px;
    }
    .qhack-intro__btn {
        width: auto;
        padding: 12px 30px;
    }
    .qhack-intro__btn-text {
        font-size: 16px;
        letter-spacing: 0.64px;
    }
    .qhack-intro__ranking-title {
        font-size: 32px;
    }
    .qhack-intro__ranking-images {
        gap: 16px;
    }
    .qhack-intro__ranking-images img {
        max-width: 160px;
    }
    .qhack-intro__ranking-note {
        font-size: 13px;
    }
    .qhack-intro__number {
        font-size: 22px;
    }
    
    /*************************** 03. 共通パーツ ***********************/
    .pc {
        display: none;
    }

    .tablet {
        display: inherit;
    }

    .sp {
        display: inherit;
    }

    .concept {
        flex-direction: column;
    }

    .concept .concept-left {
        width: 96%;
        margin: 0 auto;
    }

    .concept .tit {
        margin: 0 auto;
    }

    .concept .catchcopy {
        font-size: 3.6rem;
        text-align: center;
    }

    .concept .catchcopy br {
        display: none;
    }

    .concept .concept-right {
        width: 96%;
        margin: 0 auto;
    }

    .concept .concept-bg {
        font-size: 6rem;
    }

    .concept .concept-right p br {
        display: none;
    }

    ul.before-after li:first-child::after {
        font-size: 12rem;
    }

    ul.fourColumns li {
        width: 31.3333%;
        margin: 1%;
    }

    ul.fiveColumns li {
        width: 23%;
        margin: 1%;
    }

    ul.sixColumns li {
        width: 23%;
        margin: 1%;
    }

    .flex-container-three>* {
        width: 48%;
    }

    .flex-container-four>* {
        width: 31.3333%;
    }

    div.flow-ol-container ol {
        flex-direction: column;
        width: 100%;
        background: linear-gradient(to bottom, #f0f2f4, #999);
    }

    div.flow-ol-container ol li {
        width: 100%;
        padding: 30px 0;
        background: url(../images/icons/flow-bottom-start.svg) no-repeat center bottom, url(../images/icons/flow-bottom-end.svg) no-repeat center top;
        background-size: 160px auto;
    }

    div.flow-ol-container ol li:last-child {
        background: url(../images/icons/flow-bottom-end.svg) no-repeat center top;
        background-size: 160px auto;
        border: none;
    }

    div.flow-ol-container ol li:first-child {
        background: url(../images/icons/flow-bottom-start.svg) no-repeat center bottom;
        background-size: 160px auto;
    }

    div.flow-ol-container ol li::before {
        counter-increment: flow-list;
        content: counter(flow-list);
        display: block;
        font-size: 4.8rem;
        padding-bottom: 1rem;
    }

    .flow-section-container section {
        width: calc(50% + 6rem);
    }

    .flow-section-container section:nth-child(odd) {
        margin-left: calc(50% - 6rem);
    }

    .flow-section-container h3::before {
        width: 3rem;
        padding: 0.3rem 0;
        color: #fff;
        margin-right: 0.3rem;
    }

    .flow-section-container div.img {
        width: 12rem;
    }
    .year::before {
        top: 0;
        left: 7.8rem;
        width: 6px;
        height: 100%;
    }

    .year>ul {
        display: flex;
        align-items: baseline;
        flex-direction: column;
    }

    .year>ul>li {
        flex-direction: row;
    }

    .year>ul>li+li {
        margin: 1.5rem 0;
    }

    .year-time::before {
        right: 0;
        left: auto;
        bottom: auto;
        top: 50%;
        transform: translateX(50%) translateY(-50%) rotate(45deg);
    }

    .year-time::after {
        top: 50%;
        left: auto;
        bottom: auto;
        right: -3rem;
        transform: translateY(-50%);
    }

    .year-container {
        padding-left: 4rem;
        padding-top: 0rem;
    }

    .year-container ul {
        flex-direction: column;
    }

    .year-container li {
        margin: 0.5rem 0 0.6rem;
        -ms-writing-mode: inherit;
        writing-mode: inherit;
        text-orientation: inherit;
    }

    .year-container li span {
        -webkit-text-combine: inherit;
        -ms-text-combine-horizontal: inherit;
        text-combine-upright: inherit;
    }


    .deputy1 .right {
        margin-right: 2.4rem;
    }

    .deputy2 .philosophy-txt {
        margin-bottom: 3.2rem;
    }

    .deputy3-container {
        flex-direction: column;
    }

    .deputy3 .left {
        width: 100%;
    }

    .deputy3 .lead {
        margin-bottom: 3.2rem;
        line-height: 1.4;
    }

    .deputy3 .txt {
        line-height: 2.4;
    }

    .deputy3 .name {
        margin-top: 2.4rem;
    }

    .deputy3 .right {
        width: 100%;
        margin: 4.8rem 0 0;
    }

    .deputy3 .right .img {
        display: flex;
        justify-content: center;
        justify-content: flex-end;
    }

    .deputy4 {
        padding: 12rem 2.4rem 2.4rem;
    }

    .deputy4::before {
        font-size: 7.2rem;
        top: 2.4rem;
        left: 2.4rem;
        z-index: 0;
    }

    .deputy4 .philosophy-txt {
        font-size: 2.4rem;
    }

    .deputy4 .name {
        font-size: 1.8rem;
        margin-top: 1.6rem;
    }

    .deputy4-container {
        flex-direction: column;
        margin-top: 4rem;
    }

    .deputy4-container>* {
        width: 100%;
    }

    .deputy4-container .img {
        margin: 0 0 2.4rem;
        text-align: center;
    }


    .catch1 {
        max-width: 720px;
    }

    .catch1 p {
        font-size: 3.2rem;
    }

    .catch2 {
        max-width: 720px;
    }

    .catch2 p {
        font-size: 3.2rem;
    }


    .st1 {
        max-width: 500px;
    }

    .st1 p {
        font-size: 3.2rem;
        line-height: 8.8rem;
    }

    .st1 p span::before,
    .st1 p span::after {
        width: 12px;
    }

    .st2 {
        max-width: 500px;
    }

    .st2 p {
        font-size: 3.2rem;
        line-height: 8.8rem;
    }

    .st3 p {
        font-size: 3.2rem;
        line-height: 8.8rem;
    }

    /*************************** 04. breadcrumb（パンくず） ***********************/
    /*************************** 05. aside（サイドバー） ***********************/
    /*************************** 06. footer（フッター） ***********************/
    /* Q HACK フッター - タブレット */
    .qhack-footer__inner {
        padding: 30px 20px;
        min-height: auto;
    }
    .qhack-footer__main {
        flex-direction: column;
        gap: 30px;
    }
    .qhack-footer__logo img {
        width: 150px;
        height: auto;
    }
    .qhack-footer__nav {
        justify-content: center;
    }
    .qhack-footer__menu {
        flex-wrap: wrap;
        justify-content: center;
        gap: 24px 40px;
    }
    .qhack-footer__bottom {
        margin-top: 20px;
        gap: 8px;
    }
    .qhack-footer__privacy,
    .qhack-footer__copyright {
        font-size: 13px;
    }
    
    /* 既存SWELL用 */
    .l-footer {
        z-index: 5;
    }

    .footer-top::before {
        display: none;
    }

    .footer-box h3 {
        font-size: 30px;
    }
    
    /* Q HACK 選ばれる理由セクション - タブレット（スマホ版レイアウトを適用） */
    /* 背景SVGを非表示にし、SP用背景画像を使用 */
    .qhack-reasons__bg {
        display: none;
    }
    .qhack-reasons {
        background: url('/wp-content/uploads/2026/01/background-sp-reasons.png') no-repeat center 20px;
        background-size: 100% auto;
    }
    .qhack-reasons__inner {
        max-width: 100%;
        padding: 100px 0 80px;
    }
    .qhack-reasons__header {
        padding: 0 24px;
        margin-bottom: 30px;
    }
    .qhack-reasons__title {
        font-size: 28px;
        letter-spacing: 1.12px;
    }
    .qhack-reasons__subtitle {
        color: #313131;
        text-align: center;
        font-family: "Montserrat", sans-serif !important;
        font-size: 18px;
        font-style: normal;
        font-weight: 600;
        line-height: normal;
        letter-spacing: 0.72px;
        margin: 0;
    }
    /* PC版説明非表示、タブレット版説明表示 */
    .qhack-reasons__description--pc {
        display: none;
    }
    .qhack-reasons__description--tablet {
        display: block;
    }
    .qhack-reasons__description--sp {
        display: none;
    }
    .qhack-reasons__description {
        padding: 0 24px;
        margin-bottom: 50px;
    }
    .qhack-reasons__description p {
        font-size: 17px;
        line-height: 30px;
        letter-spacing: 0.68px;
    }
    /* タブレット版の改行を有効に */
    .qhack-reasons__description--tablet p br {
        display: inline;
    }
    .qhack-reasons__highlight {
        font-size: 19px;
        line-height: 32px;
        letter-spacing: 0.76px;
    }
    /* カードアイテム共通 - タブレットでもスマホと同じ縦並びレイアウト */
    .qhack-reasons__item {
        margin-bottom: 40px;
        padding-top: 0;
        width: 100%;
        margin-left: 0;
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }
    /* 左寄せアイテム */
    .qhack-reasons__item--left {
        justify-content: flex-start;
    }
    /* 右寄せアイテム */
    .qhack-reasons__item--right {
        justify-content: flex-end;
    }
    /* 全カード共通: 白背景、縦並び */
    .qhack-reasons__item--left .qhack-reasons__card,
    .qhack-reasons__item--right .qhack-reasons__card {
        width: calc(100% - 40px);
        max-width: none;
        padding: 40px 30px;
        background: #FFFFFF !important;
        box-shadow: 0px 4px 20px rgba(0, 0, 0, 0.08);
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    /* 左寄せカード（01, 03）の角丸・配置 */
    .qhack-reasons__item--left .qhack-reasons__card {
        border-radius: 0 20px 20px 0;
        margin-left: 0;
        margin-right: auto;
    }
    /* 右寄せカード（02, 04）の角丸・配置 */
    .qhack-reasons__item--right .qhack-reasons__card {
        border-radius: 20px 0 0 20px;
        margin-left: auto;
        margin-right: 0;
    }
    .qhack-reasons__card-body {
        max-width: 100%;
        gap: 18px;
        width: 100%;
    }
    .qhack-reasons__item--left .qhack-reasons__card-body,
    .qhack-reasons__item--right .qhack-reasons__card-body {
        margin-left: 0;
        margin-right: 0;
    }
    .qhack-reasons__card-header {
        gap: 14px;
        flex-wrap: nowrap;
        flex-direction: row;
        align-items: center;
    }
    .qhack-reasons__number {
        font-size: 52px;
        letter-spacing: 2.08px;
        line-height: 1;
    }
    .qhack-reasons__number::before {
        font-size: 52px;
        letter-spacing: 2.08px;
    }
    .qhack-reasons__card-title {
        font-size: 20px;
        letter-spacing: 0.8px;
        line-height: 1.5;
        font-weight: 700;
    }
    .qhack-reasons__card-text {
        font-size: 16px;
        line-height: 28px;
        letter-spacing: 0.64px;
    }
    /* カード本文の改行を有効にする */
    .qhack-reasons__card-text br {
        display: inline;
    }
    /* 画像配置 - カード内上部に表示（スマホ版レイアウト） */
    .qhack-reasons__item-image {
        width: 120px;
        position: static !important;
        z-index: 10;
        margin: 0 auto 24px auto;
        left: auto !important;
        right: auto !important;
        top: auto !important;
        transform: none !important;
    }
    .qhack-reasons__list {
        margin-bottom: 14px;
    }
    .qhack-reasons__list li {
        font-size: 16px;
        line-height: 28px;
        letter-spacing: 0.64px;
        padding-left: 16px;
    }
    
    /* Q HACK サポートセクション - タブレット */
    .qhack-support {
        padding: 80px 20px;
    }
    /* PC用ヘッダー・説明・コンテンツを非表示 */
    .qhack-support__header--pc {
        display: none;
    }
    .qhack-support__header--sp {
        display: none;
    }
    .qhack-support__description--pc {
        display: none;
    }
    .qhack-support__description--sp {
        display: none;
    }
    .qhack-support__content {
        /* SEO用にテキストを保持しつつ視覚的に非表示 */
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }
    /* タブレット用ヘッダー・説明・画像を表示 */
    .qhack-support__header--tablet {
        display: block;
    }
    .qhack-support__description--tablet {
        display: block;
        font-size: 18px;
        line-height: 30px;
        letter-spacing: 0.72px;
        margin-bottom: 40px;
    }
    .qhack-support__content-tablet {
        display: block;
        width: 100%;
        max-width: 900px;
        margin: 0 auto;
        padding: 0;
    }
    .qhack-support__content-tablet img {
        width: 100%;
        height: auto;
    }
    .qhack-support__title {
        font-size: 32px;
        letter-spacing: 1.28px;
    }
    .qhack-support__subtitle {
        color: #313131;
        text-align: center;
        font-family: "Montserrat", sans-serif !important;
        font-size: 18px;
        font-style: normal;
        font-weight: 600;
        line-height: normal;
        letter-spacing: 0.72px;
        margin: 0;
    }
    
    /* Q HACK サービスセクション - タブレット */
    .qhack-service__title {
        font-size: 32px;
        letter-spacing: 1.28px;
    }
    .qhack-service__subtitle {
        font-size: 18px;
        letter-spacing: 0.72px;
    }
    .qhack-service__cards {
        gap: 30px;
    }
    .qhack-service__card {
        width: 100%;
        max-width: 600px;
        min-height: auto;
        padding: 50px 30px;
        border-radius: 40px;
    }
    .qhack-service__card::before {
        border-radius: 40px;
    }
    .qhack-service__card-target {
        font-size: 18px;
    }
    .qhack-service__card-title {
        font-size: 26px;
    }
    .qhack-service__card-description {
        font-size: 16px;
        line-height: 32px;
    }
    
    /* Q HACK Qoo10攻略コラムセクション - タブレット */
    .qhack-article__title {
        font-size: 32px;
        letter-spacing: 1.28px;
    }
    .qhack-article__subtitle {
        font-size: 18px;
        letter-spacing: 0.72px;
    }
    
    /* Q HACK 成功事例セクション - タブレット */
    .qhack-case__title {
        font-size: 32px;
        letter-spacing: 1.28px;
    }
    .qhack-case__subtitle {
        font-size: 18px;
        letter-spacing: 0.72px;
    }
    
    /* Q HACK お客様の声セクション - タブレット */
    .qhack-voice__title {
        font-size: 32px;
        letter-spacing: 1.28px;
    }
    .qhack-voice__subtitle {
        font-size: 18px;
        letter-spacing: 0.72px;
    }
    
    /* Q HACK 実行力セクション - タブレット */
    .qhack-execution {
        padding: 60px 20px;
    }
    .qhack-execution__card {
        width: 100%;
        max-width: 900px;
        border-radius: 30px;
        padding: 40px 20px;
    }
    .qhack-execution__images {
        gap: 10px;
        margin-bottom: 30px;
        width: 100%;
    }
    .qhack-execution__images img {
        flex: 1;
        max-width: calc((100% - 30px) / 4);
    }
    .qhack-execution__title {
        font-size: 28px;
        line-height: 40px;
        margin: 0 0 24px;
    }
    .qhack-execution__text {
        margin-bottom: 30px;
    }
    .qhack-execution__text p {
        font-size: 18px;
        line-height: 30px;
    }
    
    /* Q HACK 攻略コラムセクション - タブレット */
    .qhack-article__more-btn {
        width: 297px;
        height: 74px;
        padding: 14px 36px;
    }
    .qhack-article__more-btn-text {
        font-size: 18px;
        letter-spacing: 0.72px;
    }
    
    /* Q HACK 成功事例セクション - タブレット */
    .qhack-case__more-btn {
        width: 297px;
        height: 74px;
    }
    
    /* Q HACK チェックリストセクション - タブレット */
    .qhack-checklist {
        height: auto;
        padding: 60px 0;
    }
    .qhack-checklist::before {
        background-image: url('/wp-content/uploads/2026/01/background-1.png');
        background-size: cover;
        background-position: center;
    }
    .qhack-checklist__inner {
        padding: 0 20px;
    }
    .qhack-checklist__card {
        width: 100%;
        max-width: 720px;
        height: auto;
        border-radius: 30px;
        background: #FFF;
        padding: 50px 40px;
    }
    .qhack-checklist__title {
        width: 100%;
        font-size: 32px;
        letter-spacing: 1.28px;
        margin: 0 0 30px;
        line-height: 1.4;
    }
    .qhack-checklist__subtitle {
        font-size: 20px;
        letter-spacing: 0.8px;
        margin: 0 0 30px;
    }
    .qhack-checklist__list {
        margin: 0 0 30px;
        gap: 16px;
        width: 100%;
    }
    .qhack-checklist__list li {
        gap: 12px;
        align-items: center;
    }
    .qhack-checklist__icon {
        width: 28px;
        height: 28px;
        flex-shrink: 0;
    }
    .qhack-checklist__list li span {
        font-size: 18px;
        letter-spacing: 0.72px;
        line-height: 1.5;
    }
    .qhack-checklist__cta-text {
        font-size: 22px;
        letter-spacing: 0.88px;
        margin: 0 0 30px;
        line-height: 1.5;
    }
    .qhack-checklist__number {
        font-size: 26px;
        letter-spacing: 1.04px;
    }
    .qhack-checklist__btn {
        width: 260px;
        height: 64px;
        padding: 12px 32px;
    }
    .qhack-checklist__btn-main {
        font-size: 16px;
        letter-spacing: 0.64px;
    }
    
    /* Q HACK よくある質問セクション - タブレット */
    .qhack-faq {
        padding: 60px 0 80px;
    }
    .qhack-faq__inner {
        max-width: 100%;
        padding: 0 20px;
    }
    .qhack-faq__header {
        margin-bottom: 40px;
    }
    .qhack-faq__title {
        font-size: 32px;
        letter-spacing: 1.28px;
    }
    .qhack-faq__subtitle {
        font-size: 18px;
        letter-spacing: 0.72px;
    }
    .qhack-faq__cards {
        gap: 30px;
    }
    .qhack-faq__card {
        width: 100%;
        max-width: 100%;
        min-height: auto;
        border-radius: 20px;
        padding: 30px 24px;
        gap: 20px;
        overflow: hidden; /* はみ出し防止 */
    }
    /* 質問エリア - アイコン中央揃え */
    .qhack-faq__question {
        gap: 16px;
        align-items: center;
    }
    .qhack-faq__q-icon {
        width: 44px;
        height: 44px;
        flex-shrink: 0;
    }
    .qhack-faq__q-icon svg {
        width: 44px;
        height: 44px;
    }
    .qhack-faq__q-text {
        font-size: 22px;
        letter-spacing: 0.88px;
    }
    .qhack-faq__question-text {
        font-size: 20px;
        letter-spacing: 0.8px;
        line-height: 1.5;
        padding-top: 0; /* 中央揃えのためpaddingを削除 */
        flex-shrink: 1; /* 縮小を許可してはみ出しを防止 */
        min-width: 0; /* Flexbox子要素の縮小を有効化 */
        width: auto;
    }
    /* 回答エリア - アイコン中央揃え */
    .qhack-faq__answer {
        gap: 16px;
        align-items: center; /* テキストをAアイコンの高さ中央に */
    }
    .qhack-faq__a-icon {
        width: 44px;
        height: 44px;
        flex-shrink: 0;
    }
    .qhack-faq__a-icon svg {
        width: 44px;
        height: 44px;
    }
    .qhack-faq__a-text {
        font-size: 22px;
        letter-spacing: 0.88px;
    }
    .qhack-faq__answer-text {
        font-size: 18px;
        letter-spacing: 0.72px;
        line-height: 1.6;
        padding-top: 0; /* 中央揃えのためpaddingを削除 */
        word-break: break-word; /* 長いテキストの折り返し */
        flex-shrink: 1; /* 縮小を許可してはみ出しを防止 */
        min-width: 0; /* Flexbox子要素の縮小を有効化 */
        width: auto;
    }
    
    /* Q HACK ご支援の流れセクション - タブレット（スマホ版レイアウトを適用） */
    .qhack-flow {
        padding: 60px 20px 80px;
    }
    .qhack-flow__inner {
        gap: 40px;
    }
    .qhack-flow__header {
        margin-bottom: 0;
    }
    .qhack-flow__title {
        font-size: 28px;
        letter-spacing: 1.12px;
        font-weight: 700;
        line-height: normal;
        margin: 0;
        padding-bottom: 0;
    }
    .qhack-flow__subtitle {
        font-size: 18px;
        letter-spacing: 0.72px;
        font-weight: 600;
        line-height: normal;
        margin: 0;
    }
    /* PC版非表示、SP版表示 */
    .qhack-flow__content--pc {
        display: none !important;
    }
    .qhack-flow__content--sp {
        display: flex !important;
        flex-direction: column;
        align-items: center;
        width: 100%;
        max-width: 500px;
        background: #F2F2F2;
        border-radius: 20px;
        padding: 40px 30px 50px;
        box-sizing: border-box;
        margin: 0 auto;
    }
    /* ステップアイテム共通 */
    .qhack-flow__step-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 100%;
        position: relative;
    }
    /* ステップラベル背後のグラデーションライン */
    .qhack-flow__step-line-sp {
        position: absolute;
        top: 8px;
        left: 50%;
        transform: translateX(-50%);
        width: 300px;
        height: 1px;
        background: linear-gradient(90deg, #FF3D3B 0%, #B701F7 100%);
        z-index: 0;
    }
    /* STEPラベル */
    .qhack-flow__step-label-sp {
        position: relative;
        z-index: 1;
        color: #FF3D3B;
        font-family: "Noto Sans JP", sans-serif;
        font-size: 16px;
        font-style: normal;
        font-weight: 700;
        line-height: normal;
        letter-spacing: 0.64px;
        background: #F2F2F2;
        padding: 0 14px;
        margin-bottom: 18px;
    }
    /* ステップ本体（画像+テキスト） */
    .qhack-flow__step-body {
        display: flex;
        flex-direction: row;
        align-items: flex-start;
        gap: 24px;
        width: 100%;
    }
    /* ステップ画像 */
    .qhack-flow__step-image {
        width: 100px;
        height: 100px;
        flex-shrink: 0;
        margin: 0;
    }
    .qhack-flow__step-image img {
        width: 100px;
        height: 100px;
        object-fit: contain;
    }
    /* ステップテキストエリア */
    .qhack-flow__step-text {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
        flex: 1;
    }
    /* ステップタイトル */
    .qhack-flow__step-title {
        align-self: stretch;
        color: #313131;
        font-family: "Noto Sans JP", sans-serif;
        font-size: 18px;
        font-style: normal;
        font-weight: 700;
        line-height: normal;
        letter-spacing: 0.72px;
        margin: 0;
        text-align: left;
    }
    /* ステップ説明文 */
    .qhack-flow__step-desc {
        color: #313131;
        font-family: "Noto Sans JP", sans-serif;
        font-size: 14px;
        font-style: normal;
        font-weight: 700;
        line-height: 22px;
        letter-spacing: 0.56px;
        margin: 0;
    }
    /* 下矢印 */
    .qhack-flow__step-arrow {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        padding: 18px 0 22px;
    }
    .qhack-flow__step-arrow svg {
        width: 18px;
        height: 14px;
    }
    /* 最後のステップは矢印なし */
    .qhack-flow__step-item--last .qhack-flow__step-arrow {
        display: none;
    }
}