*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    font-family: "Roboto", sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -ms-overflow-style: scrollbar;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    scroll-behavior: smooth;
}

@-ms-viewport {
    width: device-width;
}

article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
    display: block;
}

body {
    margin: 0;
    font-family: "Roboto", sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.4;
    color: #666;
    background: #fff;
}

.wrapper {
    width: 430px;
    /* width: 100%; */
    margin: 0 auto;
}

.search_box_Widget {
    background: #fff;
    border-radius: 15px;
    box-shadow: rgba(0, 0, 0, 0.20) 0px 1px 6px;
    margin: -100px 15px 70px 15px;
    min-height: 150px;
    position: relative;
    padding: 15px 0 30px 0;
}

.form-label {
    padding: 10px 16px 10px 56px;
    width: 100%;
    pointer-events: none;
    position: absolute;
    left: 0;
    top: 8px;
    transition: 0.2s;
    transition-timing-function: ease;
    transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
    opacity: 0.7;
    color: #1f1f1f;
    margin: 0;
}

.form-label-icon {
    position: absolute;
    left: 15px;
    top: 14px;
}

.search_box_Widget .form-control {
    padding: 10px 16px 10px 56px;
    margin: 0;
    border: 0;
    border-bottom: #C6C5C5 1px solid;
    border-radius: 0;
    font-weight: 500;
}

.date-control {
    border-bottom: 0 !important;
}

.search_box_Widget .form-control:focus {
    box-shadow: none;
}

.swap-icon {
    background: #1D3B96;
    width: 40px;
    height: 40px;
    text-align: center;
    line-height: 40px;
    border-radius: 50%;
    position: absolute;
    right: 16px;
    top: 40px;
    cursor: pointer;
}

.date-text {
    margin-left: 50px;
    margin-top: 10px;
    margin-bottom: 10px;
}

.date-text span {
    background: #BECEFF;
    padding: 8px 15px;
    border-radius: 20px;
    color: #000;
    font-weight: 500;
    margin-left: 5px;
}

.header-routetext {
    width: 200px;
    font-size: 12px;
    font-weight: 600;

}

.header-routetext span {
    max-width: 80px;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.search_box_Widget input:focus+label,
.search_box_Widget input:not(:placeholder-shown)+label {
    opacity: 0.8;
    transform: scale(0.75) translateY(-30%) translateX(-48px);
}

/* For IE Browsers*/
.search_box_Widget input:focus+label,
.search_box_Widget input:not(:-ms-input-placeholder)+label {
    opacity: 0.8;
    transform: scale(0.75) translateY(-30%) translateX(-48px);
}

.btn-div {
    position: absolute;
    width: 100%;
    bottom: -20px;
}

.btn-search {
    background: #1D3B96;
    color: #fff;
    border-radius: 25px;
    padding: 8px 30px;
}

.summary-bus {
    margin-right: 10px;
}

.summary-text {
    color: #1D3B96;
}

.summary-text1 {
    font-weight: 700;
    font-size: 18px;
}

.boarding {
    font-weight: 700;
}

.boarding img {
    width: 25px;
}

.boarding span {
    display: block;
}

.btn-clear {
    border-radius: 25px;
    padding: 8px 30px;
}

.btn-search:hover {
    background: #1D3B96;
    color: #fff;
}

.search-icon {
    position: absolute;
    right: 20px;
}

.heading-01 {
    color: #1D3B96;
    font-size: 30px;
    font-weight: 600;
}

.sub-heading {
    font-size: 20px;
    font-weight: 600;
    color: #000;
}

.header {
    background: #1C508A;
    padding: 15px 15px 15px 50px;
    color: #fff;
    position: fixed;
    left: 0;
    width: 100%;
    z-index: 100;
}

.journeydate {
    background: #fbe3c7;
    font-weight: 700;
    display: block;
    text-align: center;
    padding: 7px;
    border-radius: 25px;
}

.header-back-icon {
    position: absolute;
    left: 15px;
    top: 15px;
}

.psgr-name {
    font-weight: 700;
    color: #1C508A;
}

.total-price {
    font-weight: 700;
    color: #1C508A;
    text-align: right;
}

.dt-btn {
    background: rgb(255 255 255 / 35%);
    font-size: 14px;
    padding: 5px 10px;
    border-radius: 20px;
}

.header p {
    font-size: 11px;
    margin: 0;
    color: #e0e0e0;
}

.filter-sec {
    background: #fff;
    padding: 10px 15px;
    border-bottom: #747171 2px solid;
}

.boarding-input {
    border: #C6C5C5 1px solid;
    font-size: 14px;
    color: #000;
    padding: 6px 15px 8px 35px;
}

.boarding-bus-icon {
    position: absolute;
    left: 8px;
    top: 8px;
    height: 20px;
}

.form-control {
    border: 1px solid #cecece;
}

.form-check-input {
    border: 1px solid #b4b2b2;
}

.content {
    background: #EAEEFB;
    padding: 100px 15px 50px 15px;
}

.bus-card {
    background: #fff;
    padding: 15px;
    box-shadow: rgba(0, 0, 0, 0.20) 0px 1px 6px;
    border-radius: 15px;
    margin-bottom: 15px;
}

.bus-no {
    font-size: 28px;
    color: #1D3B96;
    font-weight: 600;
    display: flex;
    align-items: center;
}

.bus-no img {
    height: 34px;
    margin-right: 10px;
}

.price {
    color: #000;
    font-size: 22px;
    font-weight: 600;
    margin: 0;
}

.Berth {
    font-weight: 700;
    color: #1c508a;
}

hr {
    opacity: 0.8;
}

.p-tag {
    margin: 0;
    font-size: 13px;
}

.dark {
    color: #444242;
}

.gray {
    color: #747171;
}

.bus-type {
    color: #000;
    font-size: 18px;
    font-weight: 600;
    margin: 0;
}

.seat-type {
    color: #444242;
    font-size: 16px;
    font-weight: 500;
    margin: 5px 0 0 0;
}

.view-seat {
    background: #1D3B96;
    color: #fff;
    padding: 7px 25px;
    border-radius: 25px;
    white-space: nowrap;
}

.min-ct-ht {
    min-height: calc(100vh - 78px);
}

.heading-3 {
    color: #000;
    font-size: 22px;
    font-weight: 600;
    margin: 0;
}

.seat-card {
    background: #fff;
    padding: 15px;
    box-shadow: rgba(0, 0, 0, 0.20) 0px 1px 3px;
    border-radius: 15px;
    margin-bottom: 15px;
}

.seat-ht {
    /* height:60px; */
    width: 100%;
}

.seat-info-btn {
    background: #1D3B96;
    color: #fff;
    padding: 10px 25px;
    border-radius: 25px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}








/* Media Query for Mobile screens */
@media screen and (max-width: 580px) {
    .wrapper {
        width: 100% !important;
        margin: 0 !important;
        overflow: auto !important;
    }
}