/* ボタンコンポーネント */
.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(--ButtonColor2);

    width: fit-content;

    &.PositiveColor {
        --ButtonColor1: var(--ActiveColor);
        --ButtonColor2: var(--SubActiveColor);
    }

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

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

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

    &[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;
        }
    }

    &.Hidden {
        display: none;
    }
}

/* リストコンポーネント */
.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_ListHeader {
        display: grid;
        gap: 10px;
        padding: 10px 10px;
        align-items: center;
        border-bottom: 1px solid var(--LineColor);
        cursor: pointer;
        transition: all 0.2s;
        font-weight: bold;
        background-color: #fafafa;
    }
}

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

/* フォームの要素が不正な値であるなどを警告する枠線を表示する */
.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);
    }
}
/* サーフェスカード */
.UI_SurfaceCard {
    display: grid;
    gap: 14px;
    padding: 24px;
    border: 1px solid var(--LineColor);
    border-radius: 18px;
    background-color: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

/* アイコン付きタイトル行 */
.UI_IconTitleRow {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 12px;
}

.UI_IconBadge {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1em;

    &.IconBlue {
        color: #2563eb;
        background-color: #dbeafe;
    }

    &.IconGreen {
        color: #059669;
        background-color: #d1fae5;
    }
}

.UI_CardTitle {
    margin: 0;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--MainText1);
}

/* 情報パネル */
.UI_DataPanel {
    display: grid;
    gap: 8px;
    padding: 16px 18px;
    border: 1px solid var(--LineColor);
    border-radius: 14px;
    background-color: #f8fafc;
}

.UI_DataPanelLabel {
    color: var(--SubText1);
    font-size: 0.95em;
}

.UI_DataPanelValue {
    color: var(--MainText1);
    font-size: 2rem;
    font-weight: 700;
}

.UI_DataPanelSub {
    color: var(--SubText1);
    font-size: 0.95em;
}

/* キー・バリュー表示 */
.UI_KeyValueList {
    display: grid;
    gap: 10px;
    margin: 0;

    .UI_KeyValueItem {
        display: grid;
        grid-template-columns: 72px 1fr;
        gap: 8px;
        align-items: baseline;

        dt {
            color: var(--SubText1);
        }

        dd {
            margin: 0;
            font-weight: 700;
            color: var(--MainText1);
            letter-spacing: 0.06em;
        }
    }
}

/* インライン区切り */
.UI_InlineDivider {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 16px;
    color: var(--SubText1);

    margin: 20px 0px;

    &::before,
    &::after {
        content: "";
        border-top: 1px solid var(--LineColor);
    }

    span {
        font-size: 0.95em;
    }
}

/* 注意書きリスト */
.UI_NoticeList {
    display: grid;
    gap: 8px;
    padding-left: 1.2em;
    color: var(--SubText1);

    li {
        line-height: 1.7;
    }
}
