/* ボタンコンポーネント */
.UI_Button {
    border: none;
    border-radius: 5px;
    cursor: pointer;
    transition: all 0.2s;
    /* aタグをボタンにした時のための設定 */
    display: block;
    text-decoration: none;
    
    padding: 10px 20px;
    font-size: 1em;
    color: #fff;
    background-color: var(--ButtonColor1);

    width: fit-content;

    &.NegativeColor {
        --ButtonColor1: var(--SecondaryColor);
        --ButtonColor2: var(--SubSecondaryColor);
    }

    &.GrayColor {
        --ButtonColor1: var(--Gray_Light5);
        --ButtonColor2: var(--Gray_Light6);
    }

    &:hover {
        color: #fff;
        background-color: var(--ButtonColor2);
    }

    &[disabled] {
        color: var(--Gray_Light5);
        background-color: var(--Gray_Light7);
        cursor: not-allowed;
    }

    /* ボタンがi(アイコン)を含む場合の設定 */
    /* &:has(i) {
        padding: 5px 5px;
        font-size: 1.2em;
        color: var(--ButtonColor1);
        background-color: transparent;

        &:hover {
            color: var(--ButtonColor2);
            background-color: transparent;
        }

        &[disabled] {
            color: var(--Gray_Light6);
            background-color: transparent;
            cursor: not-allowed;
        }
    } */

    /* ボタンがアイコンとテキストを含む場合の設定 */
    /* &:has(i):has(span),
    &:has(i):has(div)  {
        font-size: 1em;

        &:hover {
            
        }
    } */

    /* 文字と枠線だけのボタン */
    &.OutlineButton {
        color: var(--ButtonColor1);
        background-color: transparent;
        border: 1px solid var(--ButtonColor1);

        &:hover {
            color: var(--ButtonColor2);
            background-color: transparent;
        }

        &[disabled] {
            color: var(--Gray_Light6);
            background-color: transparent;
        }
    }
    
    /* コンテンツだけのボタン */
    &.QuietButton {
        color: var(--ButtonColor1);
        background-color: transparent;

        &:hover {
            color: var(--ButtonColor2);
            background-color: transparent;
        }

        &[disabled] {
            color: var(--Gray_Light6);
            background-color: transparent;
        }
    }
}

/* リストコンポーネント */
.UI_List {
    display: grid;
    gap: 0px;
    border-top: 1px solid var(--LineColor);

    .UI_ListItem {
        display: grid;
        gap: 10px;
        padding: 10px 10px;
        align-items: center;
        border-bottom: 1px solid var(--LineColor);
        cursor: pointer;
        transition: all 0.2s;

        &:hover {
            background-color: var(--Gray_Light7);
        }
    }
}

/* フォームコンポーネント */

/* フォームの要素が不正な値であるなどを警告する枠線を表示する */
.UI_Input {
    transition: all 0.2s;

    &.Invalid {
        outline: 2px solid var(--SecondaryColor);
    }
}

.UI_Form {
    display: grid;
    gap: 15px;
    padding: 10px;

    width: 100%;
    max-width: 500px;

    & > label {
        font-weight: 300;
        font-size: 0.9em;
        color: var(--SubText1);

        display: grid;
        gap: 5px;
    }

    .RadioGroup {
        display: grid;
        gap: 5px;

        .Label {
            font-weight: 300;
            font-size: 0.9em;
            color: var(--SubText1);
        }
    }
}

/* 区分線 */
.UI_Divider {
    border: none;
    border-top: 1px solid var(--LineColor);
    margin: 10px 0;

    &.DarkBold {
        border-top: 2px solid var(--DarkLineColor);
    }
}