.wrapper-full-page{
    min-height: 70vh;
}

.font-size-1{
    font-size: 16px;
}
.nav-tabs-overflow {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
}
.nav-tabs-overflow  .nav-link{
    white-space: nowrap;
}

.tabbable .nav-tabs {
    overflow-x: auto;
    overflow-y:hidden;
    flex-wrap: nowrap;
}
.tabbable .nav-tabs .nav-link {
    white-space: nowrap;
}
  .input-group > .select2.select2-container {
    width: auto!important;
    flex: 1 1 auto!important;
}

.custom-input-group .input-group   .select2-selection--multiple, .custom-input-group .input-group  .select2-selection--single {
    height: 100%!important;
    line-height: inherit!important;
    padding: 0.5rem 1rem!important;
}
.custom-input-group .input-group-text {
    background-color: unset!important;
    border:unset!important;
}

.custom-style-input-group{
    box-shadow: unset!important;
    border-color: #8592a3;
    display: flex;
    justify-content: center;

}
.custom-style-input-group .select2-selection{
    border-top-right-radius:0!important;
    border-bottom-right-radius:0!important;
    border: 1px solid #697a8d!important;
}
.custom-style-input-group .select2-selection--multiple {
    min-height: 2.4rem!important;
}

.custom-style-input-group .select2{
    width:100%!important;
    max-width:80%;
}

.custom-style-input-group .custom-style-input-group-span{
    width:unset!important;
}
.custom-style-input-group .btn:first-child{
    border-top-right-radius:0.375rem!important;
    border-bottom-right-radius:0.375rem!important;
    padding: 0.54rem !important;
}



.custom-select2-product-result{
    display: flex;

}

.custom-select2-product-result .img-thumbnail{
    width:80px;
    max-width: 80px!important;
}
.custom-select2-product-result .product-text{
    padding:0 4px;
    font-weight: 600;
}


/*Ticket Chat List Section*/
.ticket-aside-area .card-body{
    max-height: 67vh;
}
.ticket-aside-area .list-group-item.active {
    z-index: 2;
    color:#1d2129;
    border-color: #F0F2F5;
    background-color: #F0F2F5;
}

.ticket-aside-area .list-group-item.new {
    z-index: 2;
    color:#1d2129;
   /* border-color: #DCF8C6;*/
    background-color: #D8FDD3;
}


.ticket-aside-area .list-group .list-group-item:not(.active)  {
    text-decoration: none;
    color: #32325d!important;
}

.ticket-aside-area p{
    line-height: 1;
    font-size: 12px;
}

/*Form Section*/
.chat-box {
    height: 55vh;
    overflow-y: auto;
    scroll-behavior: smooth;
}
.message {
    display: flex;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 10px;
}
.message.sent {
    background-color: #DCF8C6;
    align-self: flex-end;
}
.message.received {
    background-color: #E2E2E2;
    align-self: flex-start;
}
.message-content {
    flex-grow: 1;
    margin-left: 10px;
}
.message-time {
    font-size: 12px;
    color: #999;
}
.thumbnail {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    /* background-color: #ddd;*/
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    color: #555;
}

.table-container > .table-responsive {
    min-height: 250px!important;
}


.container-with-fixed-bottom{
    height:calc(100vh - 185px);
    overflow-y:auto;
}
.copy-on-click{
    cursor:pointer;

}
.copy-on-click:hover{
    color:#5e72e4!important;
}
.selectable-text {
    display: inline-block;
    white-space: nowrap;
}
.timeline:before {
    top:4px;
    height: 95%;
}


.timeline-step{
    align-items: initial;
}
.global-search .form-control-lg{

}
.global-search select{
    border-top-left-radius: .25rem;
    border-bottom-left-radius: .25rem;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.global-search input{
    padding:0 0.25rem;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: .25rem;
    border-bottom-right-radius: .25rem;
}

@media (max-width: 768px) {
    .custom-style-input-group .select2-selection--multiple {
        min-height: 2.40rem!important;
    }
    .custom-style-input-group .select2{
        width:100%!important;
        max-width: unset!important;
        border-top-right-radius:unset!important;
        border-bottom-right-radius:unset!important;

    }
    .custom-style-input-group .custom-style-input-group-span{
        width:100%!important;
        justify-content: center;
        text-align: center;
        margin:10px 0;
    }
    .custom-style-input-group .btn:first-child{
        border-top-left-radius:0.375rem!important;
        border-bottom-left-radius:0.375rem!important;
    }
    .container-with-fixed-bottom{
        height:calc(100vh - 160px);
        overflow-y:auto;
    }
}
@media (max-width: 576px) {
    .custom-style-input-group .select2-selection--multiple {
        min-height: 2.45rem!important;
    }
    .custom-style-input-group .select2{
        width:100%!important;
        max-width: unset!important;
        border-top-right-radius:unset!important;
        border-bottom-right-radius:unset!important;

    }
    .custom-style-input-group .custom-style-input-group-span{
        width:100%!important;
        justify-content: center;
        text-align: center;
        margin:10px 0;
    }
    .custom-style-input-group .btn:first-child{
        border-top-left-radius:0.375rem!important;
        border-bottom-left-radius:0.375rem!important;
    }
}


/* For Chrome, Safari, Edge, and Opera */
input.no-spinner::-webkit-outer-spin-button,
input.no-spinner::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* For Firefox */
input.no-spinner {
    -moz-appearance: textfield;
}
.cursor-pointer{
    cursor:pointer;
}

.photo-gallery-container {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc(100% / 2); /* Mobile: 2 per row */
    gap: 1rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding: 1rem;
}

@media (min-width: 768px) {
    .photo-gallery-container {
        grid-auto-columns: calc(100% / 4); /* Desktop: 4 per row */
    }
}

.photo-gallery-container > div {
    scroll-snap-align: start;
    flex-shrink: 0;
}

#photo-gallery {
    overflow-x: auto;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc(100% / 2); /* Mobile default */
    gap: 1rem;
    scroll-behavior: smooth;
}
@media (min-width: 576px) {
    .modal-scanner .modal-xl {
        max-width: 95vw !important;
    }
}

@media (min-width: 1200px) {
        .modal-scanner .modal-xl {
            max-width: 80vw !important;
        }
}
.form-check-input:checked + label .card {
    background-color: #e9ecef; /* Slightly gray background */
    border:1px solid var(--primary);

}
.select2-container--default .select2-selection--single {
    background-color: #fff;
    border: 1px solid #dee2e6!important;
    border-radius: 4px;
}
.select2-container--default .select2-selection--multiple {
    border: 1px solid #dee2e6!important;
    outline: 0;
}
.select2-dropdown{
    border: 1px solid #dee2e6!important;

}

.badge-stats-alert{
    display: inline-block;
    border-radius: 0.375rem;
    color:red;
    background-color: white;
    padding-left: .25rem;
    padding-right: .25rem;
}

@media (max-width: 768px) {
    .filter_body_class_custom {
        max-height: 60vh;
        overflow-y: auto;
        overflow-x: hidden;
    }
}

/* Responsive heading size */
@media (min-width: 768px) {
    .h4-md {
        font-size: 1rem !important;
        line-height: 1;
    }
    .h3-md {
        font-size: 1.75rem !important;
        line-height: 1;
    }
    .h2-md {
        font-size: 2rem !important;
        line-height: 1;
    }
    .h1-md {
        font-size: 4rem !important;
        line-height: 1;
    }
}

@media (min-width: 992px) {
    .h4-lg {
        font-size: 1.25rem !important;
        line-height: 1;
    }
    .h3-lg {
        font-size: 1.75rem !important;
        line-height: 1;
    }
    .h2-lg {
        font-size: 2.5rem !important;
        line-height: 1;
    }
    .h1-lg {
        font-size: 5rem !important;
        line-height: 1;
    }
}

@media (min-width: 1200px) {
    .h4-xl {
        font-size: 1.75rem !important;
        line-height: 1;
    }
    .h3-xl {
        font-size: 2rem !important;
        line-height: 1;
    }
    .h2-xl {
        font-size: 3rem !important;
        line-height: 1;
    }
    .h1-xl {
        font-size: 6rem !important;
        line-height: 1;
    }
}

/* Selected Collection Card */
.selected-collection-alert-card-show {
    border: none;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    overflow: hidden;
    /*box-shadow: 0 4px 18px rgba(0, 0, 0, 0.18);*/
}

.selected-collection-alert-card-show .sc-header {
    /*background: linear-gradient(135deg, #1a7a4a 0%, #28a745 100%);*/
    background: linear-gradient(135deg, var(--primary), #fff 200%);
    color: #fff;
    padding: .75rem 1rem 0.75rem;
}

.selected-collection-alert-card-show .sc-tracking-code {
    letter-spacing: 0.04em;
    color: #fff;
    opacity: 0.95;
}

.selected-collection-alert-card-show .sc-route {
    background: rgba(0,0,0,0.15);
    border-radius: 0.5rem;
    padding: 0.35rem 0.75rem;
    margin-top: 0.5rem;
    color: rgba(255,255,255,0.92);
}

.selected-collection-alert-card-show .sc-route .sc-arrow {
    color: rgba(255,255,255,0.5);
}

.selected-collection-alert-card-show .sc-stats-panel {
    border-radius: 0.5rem;
    padding:0 0.75rem 0.5rem 0.75rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #fff;
}

.selected-collection-alert-card-show .sc-stats-panel.sc-stat-packages {
    background: #fff;
    box-shadow: 0 4px 14px rgba(13,110,253,0.45);
    color: #dc3545;
}

.selected-collection-alert-card-show .collection-quantity{
    color: #dc3545;
    font-weight: 800;
    line-height: 1;
}

.selected-collection-alert-card-show .sc-stats-panel.sc-stat-weight {
    background: #dc3545;
    box-shadow: 0 4px 14px rgba(220,53,69,0.45);
    color:#fff;
}
.selected-collection-alert-card-show .collection-weight{
    color:#fff;
    font-weight: 800;
    line-height: 1;
}
.selected-collection-alert-card-show .sc-stat-value {
    font-weight: 800;
    line-height: 1;
}

.selected-collection-alert-card-show .sc-stat-label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.85;
    margin-top: 0.25rem;
}

.selected-collection-alert-card-show .sc-status-badge {
    background: rgba(255,255,255,0.2);
    color: #fff;
    border-radius: 0.4rem;
    padding: 0.25rem 0.75rem;
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border: 1px solid rgba(255,255,255,0.3);
}

.selected-collection-alert-card-show .sc-note-bar {
    background: #fff;
    color: #dc3545;
    border-top: 4px solid #dc3545;
    padding: 0.1rem 0.1rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    /*font-size: clamp(1.25rem, 5vw, 6rem);*/
    font-size: clamp(1.25rem, 8vw, 10rem);
    line-height: 1;
    text-align: center;
    width: 100%;
    display: block;
    overflow-wrap: break-word;
    word-break: break-word;
}

@media (min-width: 992px) {
    .selected-collection-alert-card-show .sc-header {
        padding: 0.8rem 1rem 0.8rem;
    }
}

@media (min-width: 1200px) {
    .selected-collection-alert-card-show .sc-header {
        padding: 0.8rem 1rem 0.8rem;
    }
}

/* Responsive input-group - md size only on larger screens */
@media (min-width: 768px) {
    .input-group-md-up > .form-control,
    .input-group-md-up > .input-group-prepend > .input-group-text,
    .input-group-md-up > .input-group-append > .input-group-text,
    .input-group-md-up > .input-group-prepend > .btn,
    .input-group-md-up > .input-group-append > .btn {
        height: calc(2.25rem + 2px);
        padding: 0.5rem 1rem;
        font-size: 1.125rem;
        line-height: 1.5;
        border-radius: 0.3rem;
    }
    .input-group-md-up > .input-group-prepend > .input-group-text,
    .input-group-md-up > .input-group-prepend > .btn {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }
    .input-group-md-up > .input-group-append > .input-group-text,
    .input-group-md-up > .input-group-append > .btn {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }
    .input-group-md-up > .form-control {
        border-radius: 0;
    }
    .input-group-md-up > .form-control:last-child {
        border-top-right-radius: 0.3rem;
        border-bottom-right-radius: 0.3rem;
    }
}

/* Bootstrap 5 Gap Utilities for Bootstrap 4 */
.gap-0 { gap: 0 !important; }
.gap-1 { gap: 0.25rem !important; }
.gap-2 { gap: 0.5rem !important; }
.gap-3 { gap: 1rem !important; }
.gap-4 { gap: 1.5rem !important; }
.gap-5 { gap: 3rem !important; }

.row-gap-0 { row-gap: 0 !important; }
.row-gap-1 { row-gap: 0.25rem !important; }
.row-gap-2 { row-gap: 0.5rem !important; }
.row-gap-3 { row-gap: 1rem !important; }
.row-gap-4 { row-gap: 1.5rem !important; }
.row-gap-5 { row-gap: 3rem !important; }

.column-gap-0 { column-gap: 0 !important; }
.column-gap-1 { column-gap: 0.25rem !important; }
.column-gap-2 { column-gap: 0.5rem !important; }
.column-gap-3 { column-gap: 1rem !important; }
.column-gap-4 { column-gap: 1.5rem !important; }
.column-gap-5 { column-gap: 3rem !important; }

/* ========== Collection Scan Manager - Workspace & Panels ========== */
#collections-scan-manage-packages-modal .scan-workspace{display:flex;gap:.75rem;height:38vh;min-height:280px}
#collections-scan-manage-packages-modal .scan-workspace-main{flex:1;min-width:0;display:flex}
#collections-scan-manage-packages-modal .scan-workspace-main>*{flex:1;width:100%}
#collections-scan-manage-packages-modal .scan-workspace-panel{flex:0 0 320px;max-width:320px;min-width:280px;display:flex;transition:flex .25s ease,max-width .25s ease,opacity .25s ease,margin .25s ease}
#collections-scan-manage-packages-modal .scan-workspace-panel>*{flex:1;width:100%}
#collections-scan-manage-packages-modal .scan-workspace-panel.panel-hidden{flex:0 0 0;max-width:0;min-width:0;opacity:0;margin-left:0;overflow:hidden}
#collections-scan-manage-packages-modal .scan-workspace-panel.panel-hidden .event-panel{border:none}

/* Results Table Card */
#collections-scan-manage-packages-modal .results-table-card{display:flex;flex-direction:column;height:100%;background:#fff;border:1px solid #e9ecef;border-radius:.5rem;overflow:hidden}
#collections-scan-manage-packages-modal .results-table-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #e9ecef;background:transparent;flex-shrink:0}
#collections-scan-manage-packages-modal .results-table-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#344767}
#collections-scan-manage-packages-modal .results-table-title i{color:#7b809a}
#collections-scan-manage-packages-modal .results-table-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .4rem;font-size:.7rem;font-weight:600;color:#fff;background:#5e72e4;border-radius:1rem}
#collections-scan-manage-packages-modal .results-table-actions{display:flex;align-items:center}
#collections-scan-manage-packages-modal .results-table-btn{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;background:transparent;border:1px solid transparent;border-radius:.375rem;color:#7b809a;cursor:pointer;transition:all .15s ease}
#collections-scan-manage-packages-modal .results-table-btn:hover{background:#f8f9fa;border-color:#e9ecef;color:#344767}
#collections-scan-manage-packages-modal .results-table-btn.active{background:#5e72e4;border-color:#5e72e4;color:#fff}
#collections-scan-manage-packages-modal .results-table-btn.active:hover{background:#4c5fd7;border-color:#4c5fd7}
#collections-scan-manage-packages-modal .results-table-body{flex:1;overflow-y:auto;overflow-x:auto}
#collections-scan-manage-packages-modal .results-table-body .table{margin-bottom:0}
#collections-scan-manage-packages-modal .results-table-body .table thead th{position:sticky;top:0;background:#f6f9fc;z-index:1;border-top:none}
#collections-scan-manage-packages-modal .results-table-body::-webkit-scrollbar{width:5px;height:5px}
#collections-scan-manage-packages-modal .results-table-body::-webkit-scrollbar-track{background:transparent}
#collections-scan-manage-packages-modal .results-table-body::-webkit-scrollbar-thumb{background:#dee2e6;border-radius:3px}
#collections-scan-manage-packages-modal .results-table-body::-webkit-scrollbar-thumb:hover{background:#adb5bd}

/* Event Panel */
#collections-scan-manage-packages-modal .event-panel{display:flex;flex-direction:column;height:100%;background:#fff;border:1px solid #e9ecef;border-radius:.5rem;overflow:hidden}
#collections-scan-manage-packages-modal .event-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #e9ecef;background:transparent;flex-shrink:0}
#collections-scan-manage-packages-modal .event-panel-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#344767}
#collections-scan-manage-packages-modal .event-panel-title i{color:#7b809a}
#collections-scan-manage-packages-modal .event-panel-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .4rem;font-size:.7rem;font-weight:600;color:#fff;background:#5e72e4;border-radius:1rem}
#collections-scan-manage-packages-modal .event-panel-badge:empty,#collections-scan-manage-packages-modal .event-panel-badge[style*="display: none"]{display:none!important}
#collections-scan-manage-packages-modal .event-panel-actions{display:flex;align-items:center;gap:.25rem}
#collections-scan-manage-packages-modal .event-panel-btn{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;background:transparent;border:1px solid transparent;border-radius:.375rem;color:#7b809a;cursor:pointer;transition:all .15s ease}
#collections-scan-manage-packages-modal .event-panel-btn:hover{background:#f8f9fa;border-color:#e9ecef;color:#344767}
#collections-scan-manage-packages-modal .event-panel-btn-clear:hover{color:#f5365c;background:rgba(245,54,92,.08);border-color:rgba(245,54,92,.2)}
#collections-scan-manage-packages-modal .event-panel-body{flex:1;overflow-y:auto;overflow-x:hidden}
#collections-scan-manage-packages-modal .event-list{list-style:none;margin:0;padding:0}
#collections-scan-manage-packages-modal .event-item{display:flex;flex-direction:column;padding:.625rem .875rem;border-bottom:1px solid #f0f2f5;border-left:3px solid transparent;background:#fff;transition:background-color .2s ease,border-color .2s ease}
#collections-scan-manage-packages-modal .event-item:last-child{border-bottom:none}
#collections-scan-manage-packages-modal .event-item-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
#collections-scan-manage-packages-modal .event-item-main{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}
#collections-scan-manage-packages-modal .event-item-icon{flex-shrink:0;font-size:.875rem}
#collections-scan-manage-packages-modal .event-tracking-code{font-family:'SF Mono',Monaco,Inconsolata,'Roboto Mono',monospace;font-size:.8125rem;font-weight:600;color:#344767;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#collections-scan-manage-packages-modal .event-timestamp{flex-shrink:0;font-size:.6875rem;color:#8898aa;font-variant-numeric:tabular-nums}
#collections-scan-manage-packages-modal .event-message{margin-top:.25rem;font-size:.75rem;color:#f5365c;line-height:1.3;word-break:break-word}
#collections-scan-manage-packages-modal .event-item.event-success{border-left-color:#2dce89;background:linear-gradient(90deg,rgba(45,206,137,.06) 0%,transparent 100%)}
#collections-scan-manage-packages-modal .event-item.event-error{border-left-color:#f5365c;background:linear-gradient(90deg,rgba(245,54,92,.04) 0%,transparent 100%)}
#collections-scan-manage-packages-modal .event-item.event-info{border-left-color:#11cdef;background:linear-gradient(90deg,rgba(17,205,239,.06) 0%,transparent 100%)}
#collections-scan-manage-packages-modal .event-item.event-warning{border-left-color:#fb6340;background:linear-gradient(90deg,rgba(251,99,64,.06) 0%,transparent 100%)}
#collections-scan-manage-packages-modal .event-icon-add{color:#2dce89}
#collections-scan-manage-packages-modal .event-icon-remove{color:#f5365c}
#collections-scan-manage-packages-modal .event-icon-change{color:#5e72e4}
#collections-scan-manage-packages-modal .event-icon-search{color:#11cdef}
#collections-scan-manage-packages-modal .event-item.event-empty{border-left-color:transparent;background:transparent;padding:2rem 1rem}
#collections-scan-manage-packages-modal .event-empty-content{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#adb5bd;text-align:center}
#collections-scan-manage-packages-modal .event-empty-content i{font-size:2rem;opacity:.5}
#collections-scan-manage-packages-modal .event-empty-content span{font-size:.8125rem}
@keyframes eventPulse{0%,100%{background-color:inherit}50%{background-color:rgba(255,193,7,.25)}}
#collections-scan-manage-packages-modal .event-item.event-highlight{animation:eventPulse .4s ease-in-out 2}
#collections-scan-manage-packages-modal .event-panel.collapsed .event-panel-body{display:none}
#collections-scan-manage-packages-modal .event-panel.collapsed{flex:0 0 auto}
#collections-scan-manage-packages-modal .event-panel.collapsed .event-panel-header{border-bottom:none}
#collections-scan-manage-packages-modal #event-panel-toggle-icon{transition:transform .2s ease}
#collections-scan-manage-packages-modal .event-panel.collapsed #event-panel-toggle-icon{transform:rotate(180deg)}
#collections-scan-manage-packages-modal .event-panel-body::-webkit-scrollbar{width:5px}
#collections-scan-manage-packages-modal .event-panel-body::-webkit-scrollbar-track{background:transparent}
#collections-scan-manage-packages-modal .event-panel-body::-webkit-scrollbar-thumb{background:#dee2e6;border-radius:3px}
#collections-scan-manage-packages-modal .event-panel-body::-webkit-scrollbar-thumb:hover{background:#adb5bd}

/* Responsive */
@media (max-width:991.98px){
    #collections-scan-manage-packages-modal .scan-workspace{flex-direction:column;height:auto}
    #collections-scan-manage-packages-modal .scan-workspace-main{min-height:300px}
    #collections-scan-manage-packages-modal .scan-workspace-panel{flex:0 0 auto;max-width:100%;min-width:100%}
    #collections-scan-manage-packages-modal .scan-workspace-panel.panel-hidden{display:none}
    #collections-scan-manage-packages-modal .event-panel{max-height:250px}
}
@media (max-width:575.98px){
    #collections-scan-manage-packages-modal .scan-workspace-main{min-height:250px}
}

/* ========================================
   Client Notifications V3
   ======================================== */
.cn-v3 .cn-v3-dropdown {
    width: 340px;
    max-width: 90vw;
    max-height: 75vh;
}

.cn-v3 .cn-v3-list {
    max-height: 66vh;
    min-height: 250px;
    overflow-y: auto;
}

.cn-v3 .cn-v3-loading-container {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 250px;
    height: 100%;
}

.cn-v3 .cn-v3-item {
    padding: 0.25rem 0.5rem !important;
    transition: background-color 0.15s ease;
}

.cn-v3 .cn-v3-item:hover {
    background-color: #f8f9fa !important;
}

.cn-v3 .cn-v3-item--unread {
    background-color: rgba(67, 189, 0, 0.05);
}

.cn-v3 .cn-v3-item--new {
    animation: cnV3Pulse 0.5s ease-in-out;
}

.cn-v3 .cn-v3-item__icon {
    width: 20px;
    flex-shrink: 0;
    font-size: 0.9rem;
}

.cn-v3 .cn-v3-item__content {
    min-width: 0;
}

.cn-v3 .cn-v3-item__title {
    font-size: 0.8rem;
    line-height: 1.4;
    word-wrap: break-word;
    margin-bottom: 2px;
}

.cn-v3 .cn-v3-item__title strong {
    color: #5e72e4;
}

.cn-v3 .cn-v3-item__text {
    font-size: 0.75rem;
    line-height: 1.4;
    word-wrap: break-word;
    white-space: pre-wrap;
}

.cn-v3 .cn-v3-item__time {
    font-size: 0.7rem;
}

.cn-v3 .cn-v3-loading-more {
    border-top: 1px solid #e9ecef;
}

.cn-v3 .cn-v3-empty {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    min-height: 250px;
    height: 100%;
    padding: 2rem 1rem;
}

.cn-v3 .cn-v3-empty__icon {
    font-size: 2rem;
    color: #adb5bd;
    display: block;
    margin-bottom: 0.5rem;
}

/* Google Spinner for CN-V3 */
.cn-v3 .google-spinner {
    width: 24px;
    height: 24px;
}

.cn-v3 .spinner-svg {
    width: 100%;
    height: 100%;
    animation: spinner-rotate 1.4s linear infinite;
}

.cn-v3 .spinner-path {
    stroke: #4285f4;
    stroke-linecap: round;
    animation: spinner-dash 1.4s ease-in-out infinite;
}

@keyframes spinner-rotate {
    100% { transform: rotate(360deg); }
}

@keyframes spinner-dash {
    0% { stroke-dasharray: 1, 200; stroke-dashoffset: 0; }
    50% { stroke-dasharray: 89, 200; stroke-dashoffset: -35; }
    100% { stroke-dasharray: 89, 200; stroke-dashoffset: -124; }
}

@keyframes cnV3Pulse {
    0% { background-color: rgba(67, 189, 0, 0.2); }
    100% { background-color: transparent; }
}

/* Toast Container - Stacked Design */
.cn-v3-toast-container {
    position: fixed;
    bottom: 20px;
    left: 20px;
    z-index: 9999;
}

/* Stack counter badge */
.cn-v3-toast-container .cn-v3-stack-counter {
    position: absolute;
    top: -10px;
    right: -10px;
    background: #5e72e4;
    color: #fff;
    font-size: 0.7rem;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 12px;
    z-index: 10;
    box-shadow: 0 2px 6px rgba(94, 114, 228, 0.4);
    animation: cnV3CounterPop 0.2s ease-out;
}

@keyframes cnV3CounterPop {
    from { transform: scale(0.8); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}

.cn-v3-toast-container .cn-v3-toast {
    position: absolute;
    bottom: 0;
    left: 0;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    min-width: 280px;
    max-width: 360px;
    overflow: hidden;
    border: none;
    cursor: pointer;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                opacity 0.3s ease,
                box-shadow 0.2s ease;
}

/* First toast (top of stack) - fully visible */
.cn-v3-toast-container .cn-v3-toast:first-child {
    position: relative;
    z-index: 3;
    animation: cnV3SlideIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Second toast - peeking behind */
.cn-v3-toast-container .cn-v3-toast:nth-child(2) {
    z-index: 2;
    transform: translateY(-8px) scale(0.96);
    opacity: 0.7;
    pointer-events: none;
}

/* Third toast - further back */
.cn-v3-toast-container .cn-v3-toast:nth-child(3) {
    z-index: 1;
    transform: translateY(-14px) scale(0.92);
    opacity: 0.4;
    pointer-events: none;
}

/* Hide toasts beyond third */
.cn-v3-toast-container .cn-v3-toast:nth-child(n+4) {
    display: none;
}

.cn-v3-toast-container .cn-v3-toast:first-child:hover {
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__inner {
    display: flex;
    align-items: flex-start;
    padding: 10px 12px;
    gap: 10px;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__icon {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 0.8rem;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__content {
    flex: 1;
    min-width: 0;
    padding-right: 8px;
    max-height: 280px;
    overflow-y: auto;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__title {
    font-size: 0.75rem;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0 0 4px 0;
    line-height: 1.4;
    word-wrap: break-word;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__text {
    font-size: 0.7rem;
    color: #666;
    margin: 0;
    line-height: 1.5;
    white-space: pre-wrap;
    word-wrap: break-word;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__time {
    font-size: 0.65rem;
    color: #999;
    margin-top: 3px;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__close {
    position: absolute;
    top: 6px;
    right: 6px;
    width: 18px;
    height: 18px;
    border: none;
    background: rgba(0,0,0,0.05);
    border-radius: 4px;
    font-size: 0.7rem;
    color: #999;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s;
}

.cn-v3-toast-container .cn-v3-toast:first-child:hover .cn-v3-toast__close {
    opacity: 1;
}

.cn-v3-toast-container .cn-v3-toast .cn-v3-toast__close:hover {
    background: rgba(0,0,0,0.1);
    color: #333;
}

/* Animation for new toast sliding in */
@keyframes cnV3SlideIn {
    from { transform: translateX(-100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

/* Animation for toast sliding out */
@keyframes cnV3SlideOut {
    from { transform: translateX(0); opacity: 1; }
    to { transform: translateX(-100%); opacity: 0; }
}

/* Animation for stack promotion (when top toast is dismissed) */
@keyframes cnV3StackPromote {
    from { transform: translateY(-8px) scale(0.96); opacity: 0.7; }
    to { transform: translateY(0) scale(1); opacity: 1; }
}

/* Host (outer box) — sized to match the zone Select2 / Bootstrap form-control */
gmp-place-autocomplete {
    border: 1px solid #dee2e6 !important;
    box-shadow: 0 3px 2px rgba(233, 236, 239, .05) !important;
}

/* Inner input — fills the host, no double border, matches form-control padding */
gmp-place-autocomplete::part(input) {
    width: 100% !important;
    height: calc(1.5em + 0.75rem) !important;
    padding: 0.375rem 0.75rem !important;
    font-size: 1rem !important;
    line-height: 1.5 !important;
    color: #495057 !important;
    border: none !important;
    background-color: transparent !important;
    box-sizing: border-box !important;
}
gmp-place-autocomplete::part(input):focus {
    box-shadow: none !important;
    outline: none !important;
}

/* When the element sits inside an .input-group, behave like a flex form-control */
.input-group > gmp-place-autocomplete {
    flex: 1 1 auto !important;
    width: 1% !important;
    min-width: 0 !important;
}

/* ── Google Map container (used by show-package edit modals + create flows) ── */
.gmp-map-container,
#r_user-location-map,
#user-location-map,
#consignee-location-map {
    border: 1px solid #dee2e6 !important;
    border-radius: 4px !important;
    overflow: hidden !important;
    box-shadow: 0 3px 2px rgba(233, 236, 239, .05);
}

/* Suppress the focus outline that appears on the new AdvancedMarkerElement when
   it's clicked or dragged — that's the "black border" you saw. */
gmp-advanced-marker,
gmp-advanced-marker:focus,
gmp-advanced-marker:focus-visible {
    outline: none !important;
    box-shadow: none !important;
}

/* And drop the browser focus outline that Google's map sometimes paints on its
   own internal focusable container. */
[id$="-location-map"]:focus,
[id$="-location-map"] *:focus,
[id$="-location-map"] *:focus-visible {
    outline: none !important;
}


.notification-media-chip { display: inline-flex; align-items: center; gap: 6px; padding: 3px 10px; margin-right: .35rem; border-radius: 999px; background: #eef1ff; color: #4e73df; font-size: .8rem; line-height: 1; text-decoration: none; border: 1px solid #dde3ff; }
.notification-media-chip:hover { background: #4e73df; color: #fff; text-decoration: none; }
.notification-media-chip i { font-size: .85rem; }