.container:has(.budget-web) {
    flex-direction: row;
    width: 100%;
    display: flex;
}
.budget-web {
    display: flex;
    flex-direction: row;
    gap: 15px;
    width: 100%;
    height: 100%;
    padding: 20px 20px;
}

.bud-web-body {
    width: 100%;
}

.bud-web-structure-container {
    min-width: 20px;
    width: 280px;
}

.bud-web-list-container {
    flex-grow: 1;
    flex-direction: column;
    max-height: 1080px;
}

.bud-web-list-sub-wrapper {
    padding: 10px 0px 10px;
    background-color: transparent;
    flex-direction: column;
    justify-content: space-between;
}

.bud-web-main-wrapper {
    padding: 10px 0px 10px;
}

.bud-web-date-wrapper {
    display: flex !important;
    width: 200px;
    height: 40px;
    width: fit-content;
    background: #ffffff 0% 0% no-repeat padding-box;
    border: 2px solid #5c5fc0;
    border-radius: 10px;
    opacity: 1;
    align-items: center !important;
}

    .bud-web-date-wrapper .material-icons {
        margin: 10px;
        color: #5c5fc0;
    }

    .bud-web-date-wrapper input {
        font-size: var(--lg-font);
        font-weight: var(--bold-font);
        text-align: left;
        width: 150px;
        padding-left: 15px;
        border: transparent;
        background: transparent;
        color: #5c5fc0;
    }

    .bud-web-date-wrapper button {
        height: 40px;
        color: #ffffff;
        background: #5c5fc0;
        width: 80px;
        border: none;
        border-radius: 0px 8px 8px 0px;
        opacity: 1;
    }

.bud-web-list-date {
    justify-content: space-between;
    margin-left:24px;
    display: flex;
    gap: 0.5rem;
}

.bud-web-sidebar-wrapper {
    padding: 10px 0px;
    gap: 10px;
    display: flex;
    flex-direction: column;
}
.bud-selected-menu {
    color: #5C5FC0;
}
.bud-web-menu-list {
    display: flex;
    flex-direction: column;
    width: 190px;
    height: 100%;
    margin-top: 9px;
    padding: 0px 0px;
    /* UI Properties */
    background: #ffffff 0% 0% no-repeat padding-box;
    box-shadow: 0px 3px 6px #00000029;
    border-radius: 10px;
    opacity: 1;
}

    .bud-web-menu-list span {
        font-size: var(--lg-font);
        padding-left: 20px;
        margin-top: 15px;
    }

    .bud-web-divider {
        width: 170px;
        height: 1px;
        padding-left: 10px;
        margin-top: 13px;
        background-color: #e1e1e1;
        margin: 13px 10px;
    }

.bud-web-user-lookup {
    justify-content: space-between;
    font-size: var(--lg-font);
    align-items: center;
    color: #ffffff;
    display: flex;
    padding: 15px;
    width: 190px;
    height: 40px;
    /* UI Properties */
    background: #5c5fc0 0% 0% no-repeat padding-box;
    box-shadow: 0px 3px 6px #00000029;
    border-radius: 10px;
}

    .bud-web-user-lookup .material-icons {
        font-size: 12px;
        justify-content: flex-end;
    }

.date-buttons {
    display: flex;
    gap: 10px;
    margin-left: auto;
}

.bud-web-button {
    display: flex;
    justify-content: center;
    width: 200px;
    height: 40px;
    /* UI Properties */
    background: #ffffff 0% 0% no-repeat padding-box;
    border: 2px solid #5c5fc0;
    border-radius: 10px;
    opacity: 1;
    overflow: hidden;
    position: relative;
}

    .bud-web-button button {
        text-align: center;
        font-weight: bold;
        color: #5c5fc0;
        background: #fff 0% 0% no-repeat padding-box;
        border: none;
        border-radius: 10px;
        opacity: 1;
        position: relative;
        overflow: visible !important;
    }

        .bud-web-button button:hover {
            cursor: pointer;
            text-align: center;
            font-weight: bold;
            color: #fff;
            background: #5c5fc0 0% 0% no-repeat padding-box;
            border: none;
            border-radius: 7px;
            opacity: 1;
            position: relative;
            overflow: visible !important;
        }




.bud-web-body-top-wrapper {
    justify-content: space-between;
    display: flex;
    display: flex;
    margin-top: 10px;
    gap: 20px;
    margin-left: auto;
}

.bud-web-list-sub-wrapper {
    display: flex;
    padding: 10px 0px 10px;
    background-color: transparent;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

    .bud-web-list-sub-wrapper expense-table {
        box-shadow: 0px 3px 6px transparent;
    }

    .bud-web-list-sub-wrapper td {
        text-align: center;
    }

    .bud-web-list-sub-wrapper th {
        text-align: center;
    }

.bud-web-selct-date {
    color: #5c5fc0;
    letter-spacing: 0;
    font-size: var(--xxlg-font);
    font-weight: var(--bold-font);
    height: 100%;
    display: flex;
    align-items: center;
}


input {
    padding: 5px 10px;
    font-size: 16px;
}

.budget-icon {
    cursor: pointer;
    font-size: 24px;
}

button {
    padding: 5px 15px;
    font-size: 16px;
}

/* 달력 팝업 스타일 */
.calendar-popup {
    position: absolute;
    background: #fff;
    border: 1px solid #ccc;
    padding: 10px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
}

.calendar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.calendar-body {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 5px;
    margin-top: 10px;
}

    .calendar-body div {
        padding: 10px;
        text-align: center;
        cursor: pointer;
    }

        .calendar-body div:hover {
            background-color: #f0f0f0;
        }

.bud-web-detail-list-wrapper {
    display: flex;
    flex-wrap: wrap;
    padding: 0 0 0 0;
}

.bud-web-detail-list-sub-wrapper-col {
    display: flex;
    padding: 10px 15px 0;
    background-color: transparent;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
}

.bud-web-detail-table-area {
}

.bud-web-detail-table-wrapper {
    padding: 6px;
    width: 331px;
    background-color: white;
    border: 1px solid white;
    border-radius: 10px;
    box-shadow: 0px 3px 6px #5c5fc033;
}

.bud-web-detail-table {
    padding: 0 10px 62px;
    width: 100%;
    border-radius: 10px;
    border-collapse: collapse;
    background-color: transparent;
    margin-top: 0px;
}

    .bud-web-detail-table th {
        background-color: transparent;
        /*border: 1px solid black;*/
    }

    .bud-web-detail-table tr {
        background-color: transparent;
        /*border: 1px solid black;*/
    }

/*법인카드*/
.bud-web-detail-table-type-card {
    line-height: 1;
    text-align: center;
    font-size: 8px;
    font-weight: normal;
    color: #4c4c4c;
}

.bud-web-detail-table-type-cash {
    line-height: 1;
    text-align: center;
    font-size: 10px;
    font-weight: normal;
    color: #ff5a81;
}
/*날짜*/
.bud-web-detail-table-date {
    text-align: center;
    font-size: var(--xxsm-font);
    font-weight: normal;
    color: #4c4c4c;
}
/*금액*/
.bud-web-detail-table-amount {
    text-align: left;
    padding-left: 6px;
    font-size: 24px;
    font-weight: bold;
    color: #4c4c4c;
}
    /*원*/
    .bud-web-detail-table-amount a {
        text-align: left;
        padding-left: 4px;
        font-size: var(--xsm-font);
        font-weight: normal;
        color: #888888;
    }
/*거래처*/
.bud-web-detail-table-text {
    text-align: left;
    padding-left: 6px;
    font-weight: normal;
    font-size: var(--xsm-font);
    color: #888888;
}
/*비고*/
.bud-web-detail-table-remark {
    text-align: left;
    padding-left: 6px;
    font-size: var(--xsm-font);
    font-weight: normal;
    color: #3376d0;
}
/*기호*/
.bud-web-detail-table-circle {
    display: flex;
    justify-content: center; /* 오른쪽 정렬 */
    align-items: center; /* 세로 중앙 정렬 */
}

.circle-default {
    text-align: center;
    font-size: 22px;
    border: 1px solid #888888;
    width: 16px;
    height: 16px;
    border-radius: 50%;
}

.circle-blue {
    text-align: center;
    font-size: 22px;
    border: 1px solid #888888;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: #3376d0;
}

.circle-red {
    text-align: center;
    font-size: 22px;
    border: 1px solid #888888;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background-color: #ff5a81;
}

.bud-web-claendar-icon {
    align-items: center;
    color: #5C5FC0;
    padding-right: 15px;
}

.expense-table .bud-report-highlight {
    background-color: #5C5FC0;
    color: #FFFFFF;
}
.bud-report-border {
    border-bottom: 2px solid black;
}
.bud-report-border-left{
    border-left: 2px solid black;
}
.bud-report-border-right {
    border-right: 2px solid black;
}




.expense-table table tr td button {
    position: relative;
    height: 100%;
    width: 100%;
    overflow: hidden;
    cursor: pointer;
    color: gray;
    background-color: transparent;
    border-color: transparent;
}
    .expense-table table tr td button:hover {
        cursor: pointer;
        font-weight: bolder;
        color: #5C5FC0;
        background-color: transparent;
        border-color: transparent;
    }

    .hidden{
        display: none;
    }
.budget-import-title {
    height:40px;
    display: flex;
    justify-content: left;
    align-items: center;
}

.bud-web-ongoing-search-area {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    padding: 20px 0 10px 0;
    align-items:center;
}
.bud-web-upload-search-area {
    display: flex;
    flex-direction: row;
    gap: 1rem;
    padding: 20px 0 10px 0;
    align-items: center;
}

.bud-web-ongoing-search-btn {
    display: flex;
    width: 50px;
    height: 30px;
    align-items: center;
    justify-content: center;
    background-color: white;
    color: #5c5fc0;
    border: 1px solid #5c5fc0;
    cursor: pointer;
}
.bud-web-upload-search-btn {
    display: flex;
    width: 50px;
    height: 30px;
    align-items: center;
    justify-content: center;
    background-color: white;
    color: #5c5fc0;
    border: 1px solid #5c5fc0;
    cursor: pointer;
}

.bud-web-search-btn:hover {
    background-color: #5c5fc0;
    color: white;
}

.budget-web-import-ongiong-input {
    height: 25px !important;
    width: 250px !important;
    border: 1px solid #9a9e9c !important;
    padding-left: 8px !important;
}

    .budget-web-import-ongiong-input:focus {
        border-color: #5c5fc0 !important;
        outline: none !important;
    }
.budget-web-import-upload-input {
    height: 25px !important;
    width: 250px !important;
    border: 1px solid #9a9e9c !important;
    padding-left: 8px !important;
}

    .budget-web-import-upload-input:focus {
        border-color: #5c5fc0 !important;
        outline: none !important;
    }
.bud-web-ongoing-search-case-date {
    display: none;
    flex-direction: row;
    gap: 1rem;
}
.bud-web-ongoing-search-case-status {
    display: none;
    flex-direction: row;
    gap: 1rem;
}
.bud-web-ongoing-search-case-number {
    display: none;
    flex-direction: row;
    gap: 1rem;
}

.bud-web-upload-search-case-date {
    display: none;
    flex-direction: row;
    gap: 1rem;
}

.bud-web-upload-search-case-status {
    display: none;
    flex-direction: row;
    gap: 1rem;
}

.bud-web-upload-search-case-number {
    display: none;
    flex-direction: row;
    gap: 1rem;
}

/* -------------------------select box custom----------------------- */
.budget-import-ongoing-select {
    width: 250px !important;
    height: 25px !important;
    padding: 2px 7px !important;
    font-size: var(--sm-font) !important;
    color: #333 !important;
    background-color: #f9f9f9 !important;
    border: 1px solid #9a9e9c !important;
    border-radius: 5px !important;
    appearance: none !important; /* Remove default dropdown arrow */
    -webkit-appearance: none !important;
    -moz-appearance: none;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    outline: none;
    cursor: pointer;
    transition: all 0.3s ease;
    background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"%3E%3Cpath d="M6 9l6 6 6-6"%3E%3C/path%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 5px center;
    background-size: 10px; /* Adjusted arrow size */
}

/* Add a custom dropdown arrow */
.budget-import-ongoing-select-container::after {
    content: "\\25BC"; /* Downward triangle arrow */
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    font-size: 12px;
    color: #333;
    pointer-events: none;
}

/* Hover and focus styles */
.budget-import-ongoing-select:hover {
    background-color: #f1f1f1;
}

.budget-import-ongoing-select:focus {
    border-color: #5c5fc0;
    box-shadow: 0 0 5px #5c5fc0;
}

/* -------------------------select box custom----------------------- */
.budget-import-upload-select {
    width: 250px !important;
    height: 25px !important;
    padding: 2px 7px !important;
    font-size: var(--sm-font) !important;
    color: #333 !important;
    background-color: #f9f9f9 !important;
    border: 1px solid #9a9e9c !important;
    border-radius: 5px !important;
    appearance: none !important; /* Remove default dropdown arrow */
    -webkit-appearance: none !important;
    -moz-appearance: none;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    outline: none;
    cursor: pointer;
    transition: all 0.3s ease;
    background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"%3E%3Cpath d="M6 9l6 6 6-6"%3E%3C/path%3E%3C/svg%3E');
    background-repeat: no-repeat;
    background-position: right 5px center;
    background-size: 10px; /* Adjusted arrow size */
}

/* Add a custom dropdown arrow */
.budget-import-upload-select-container::after {
    content: "\\25BC"; /* Downward triangle arrow */
    position: absolute;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    font-size: 12px;
    color: #333;
    pointer-events: none;
}

/* Hover and focus styles */
.budget-import-upload-select:hover {
    background-color: #f1f1f1;
}

.budget-import-upload-select:focus {
    border-color: #5c5fc0;
    box-shadow: 0 0 5px #5c5fc0;
}

.budget-web-table-top {
    display: flex;
    border: 1px solid #5c5fc0;
    border-radius: 10px 10px 0px 0px;
    background-color: #5c5fc0;
    color: white;
    width: 100%;
    /*width: 1430px;*/
    height: 50px;
    justify-content: left;
    align-items: center;
    font-size: var(--xlg-font);
    font-weight: var(--normal-font);
    padding: 0 0 0 20px;
}
.budget-web-table-bottom {
    border-radius: 0px 0px 10px 10px;
    background-color: #ffffff;
    width: 100%;
    /*width: 1430px;*/
    height: 100%;
    max-height: 100%;
    box-shadow: 0px 3px 6px #00000029;
    padding: 20px;
}
.budget-web-area {
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
}
.budget-web-body-bottom-wrapper{
    padding-top:20px;
}