/*矢印付き共通ボタン (c-arrow-button)*/

/*base（基本構造）*/
.c-arrow-button {
    display: flex;
    justify-content: space-between;
    align-items: center;

    width: 100%;
    padding: 20px 30px;

    text-decoration: none;
    border-radius: 5px;
    box-sizing: border-box;
    border: 2px solid transparent;
    transition: all 0.3s ease;
}

.c-arrow-button:hover {
    opacity: 0.8;
}

/*text*/
.c-arrow-button__text {
    font-weight: bold;
    font-size: 18px;
    color: #fff;

    white-space: nowrap;

    transition: color 0.3s ease;
}

/*icon*/
.c-arrow-button__icon {
    display: block;

    width: 32px;
    height: 32px;

    background-color: #fff;
    border-radius: 50%;

    position: relative;
    flex-shrink: 0;

    transition: background-color 0.3s ease;
}

/*arrow*/
.c-arrow-button__icon::after {
    content: "";
    display: block;

    width: 8px;
    height: 8px;

    border-top: 2px solid;
    border-right: 2px solid;

    transform: rotate(45deg);

    position: absolute;
    top: 55%;
    left: 30%;

    margin-top: -5px;

    border-color: inherit;
}

/*outline variant（サービス一覧用)*/
.c-arrow-button.--outline {

    display: inline-flex;
    justify-content: flex-start;
    align-items: center;

    width: auto;
    padding: 12px 20px;

    gap: 15px;

    background-color: #fff;
    border: 1px solid #333;

    color: #333;
}

/* text */
.c-arrow-button.--outline .c-arrow-button__text {
    font-size: 22px;
    color: #333;
}

/* icon */
.c-arrow-button.--outline .c-arrow-button__icon {
    background-color: #333;
}

.c-arrow-button.--outline .c-arrow-button__icon::after {
    border-color: #fff;
}


/* hover */
.c-arrow-button.--outline:hover {
    opacity: 1;
    border-color: var(--wp--preset--color--main-color);
}

.c-arrow-button.--outline:hover .c-arrow-button__text {
    color: var(--wp--preset--color--main-color);
}

.c-arrow-button.--outline:hover .c-arrow-button__icon {
    background-color: var(--wp--preset--color--main-color);
}

/* consulting hover */
.p-services__consulting .c-arrow-button.--outline:hover {
    border-color: var(--wp--preset--color--sub-color-1);
}

.p-services__consulting .c-arrow-button.--outline:hover .c-arrow-button__text {
    color: var(--wp--preset--color--sub-color-1);
}

.p-services__consulting .c-arrow-button.--outline:hover .c-arrow-button__icon {
    background-color: var(--wp--preset--color--sub-color-1);
}

/*size variation*/
.c-arrow-button.--sm {
    display: flex;
    align-items: center;

    padding: 10px 50px 10px 15px;

    position: relative;
}


.c-arrow-button.--sm .c-arrow-button__text {
    display: block;

    font-size: 14px;
    line-height: 1.4;
}

.c-arrow-button.--sm .c-arrow-button__icon {
    width: 20px;
    height: 20px;

    position: absolute;
    right: 15px;
    top: 50%;

    transform: translateY(-50%);

    pointer-events: none;
}

.c-arrow-button.--sm .c-arrow-button__icon::after {
    width: 6px;
    height: 6px;

    margin-top: -4px;
}

/*color variation*/
.c-arrow-button.--orange {
    background-color: var(--wp--preset--color--main-color);
    color: var(--wp--preset--color--main-color);
}

.c-arrow-button.--deep-orange {
    background-color: var(--wp--preset--color--sub-color-1);
    color: var(--wp--preset--color--sub-color-1);
}

.c-arrow-button.--dark {
    background-color: var(--wp--preset--color--sub-color-2);
    color: var(--wp--preset--color--sub-color-2);
}

.c-arrow-button.--white {
    background-color: var(--wp--preset--color--white);
    color: var(--wp--preset--color--main-color);
}

.c-arrow-button.--white .c-arrow-button__text {
    color: var(--wp--preset--color--main-color);
}

.c-arrow-button.--white .c-arrow-button__icon {
    background-color: var(--wp--preset--color--main-color);
}

.c-arrow-button.--white .c-arrow-button__icon::after {
    border-color: var(--wp--preset--color--white);
}

.c-arrow-button.--white-deep {
    background-color: var(--wp--preset--color--white);
    /* 初期状態の枠線をデザイン案に合わせて白に設定 */
    border: 1px solid var(--wp--preset--color--white);
    color: var(--wp--preset--color--sub-color-1);
}

.c-arrow-button.--white-deep .c-arrow-button__text {
    color: var(--wp--preset--color--sub-color-1);
}

.c-arrow-button.--white-deep .c-arrow-button__icon {
    background-color: var(--wp--preset--color--sub-color-1);
}

.c-arrow-button.--white-deep .c-arrow-button__icon::after {
    border-color: var(--wp--preset--color--white);
}

/* --- カラーバリエーションごとのホバー演出 --- */

/* 1. オレンジ (--orange) */
.c-arrow-button.--orange:hover {
    background-color: #fff !important;
    color: var(--wp--preset--color--main-color) !important;
    border-color: var(--wp--preset--color--main-color) !important;
}
.c-arrow-button.--orange:hover .c-arrow-button__text {
    color: var(--wp--preset--color--main-color) !important;
}
.c-arrow-button.--orange:hover .c-arrow-button__icon {
    background-color: var(--wp--preset--color--main-color) !important;
}
.c-arrow-button.--orange:hover .c-arrow-button__icon::after {
    border-color: #fff !important;
}

/* 2. ディープオレンジ (--deep-orange) */
.c-arrow-button.--deep-orange:hover {
    background-color: #fff !important;
    color: var(--wp--preset--color--sub-color-1) !important;
    border-color: var(--wp--preset--color--sub-color-1) !important;
}
.c-arrow-button.--deep-orange:hover .c-arrow-button__text {
    color: var(--wp--preset--color--sub-color-1) !important;
}
.c-arrow-button.--deep-orange:hover .c-arrow-button__icon {
    background-color: var(--wp--preset--color--sub-color-1) !important;
}
.c-arrow-button.--deep-orange:hover .c-arrow-button__icon::after {
    border-color: #fff !important;
}

/* 3. ダーク (--dark) */
.c-arrow-button.--dark:hover {
    background-color: #fff !important;
    color: var(--wp--preset--color--sub-color-2) !important;
    border-color: var(--wp--preset--color--sub-color-2) !important;
}
.c-arrow-button.--dark:hover .c-arrow-button__text {
    color: var(--wp--preset--color--sub-color-2) !important;
}
.c-arrow-button.--dark:hover .c-arrow-button__icon {
    background-color: var(--wp--preset--color--sub-color-2) !important;
}
.c-arrow-button.--dark:hover .c-arrow-button__icon::after {
    border-color: #fff !important;
}

/* hover演出：ディープオレンジに塗りつぶし */
.c-arrow-button.--white:hover,
.c-arrow-button.--white-deep:hover {
    background-color: transparent;
    border-color: var(--wp--preset--color--white) !important;
    color: #fff !important;
    opacity: 1; /* opacity 0.8を打ち消し */
}

.c-arrow-button.--white:hover .c-arrow-button__text,
.c-arrow-button.--white-deep:hover .c-arrow-button__text  {
    color: #fff !important;
}

.c-arrow-button.--white:hover .c-arrow-button__icon,
.c-arrow-button.--white-deep:hover .c-arrow-button__icon {
    background-color: #fff !important;
}

.c-arrow-button.--white:hover .c-arrow-button__icon::after,
.c-arrow-button.--white-deep:hover .c-arrow-button__icon::after {
    border-color: var(--wp--preset--color--main-color) !important;
}