.travelgate-booking-widget {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    max-width: 380px;
    margin: 0 auto;
    color: #16304a
}

.travelgate-booking-widget .tg-card {
    background: #fff;
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 16px;
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
    border: 1px solid #e6eef7
}

.tg-price-from {
    display: flex;
    align-items: baseline;
    gap: 8px
}

.tg-from-label {
    color: #d64545;
    font-weight: 600
}

.tg-price {
    color: #d64545;
    font-size: 22px;
    font-weight: 700
}

.tg-regular-price {
    font-size: 12px;
    color: #7b8b9a;
    margin-top: 6px
}

.tg-strike {
    text-decoration: line-through;
    color: #9aa7b5
}

.tg-discount {
    margin-top: 8px;
    font-size: 13px;
    color: #0b69b3
}

.tg-discount-badge {
    background: #0b69b3;
    color: #fff;
    padding: 4px 8px;
    border-radius: 6px;
    font-weight: 700;
    margin-left: 6px
}

.tg-note {
    font-size: 12px;
    color: #6c7b88;
    margin-top: 8px
}

.tg-summary-card {
    border: 2px solid #1f6fbf;
    background: linear-gradient(180deg, #ffffff, #f7fbff);
    padding: 14px
}

.tg-summary-title {
    font-size: 14px;
    color: #0b3b66;
    font-weight: 700
}

.tg-summary-amount {
    background: #fff;
    border: 1px solid #1f6fbf;
    padding: 6px 8px;
    border-radius: 6px;
    margin-left: 8px;
    color: #1f6fbf
}

.tg-summary-sub {
    font-size: 12px;
    color: #5a7186;
    margin-top: 6px
}

.tg-summary-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px
}

.tg-btn.small {
    font-size: 12px;
    padding: 6px 10px;
    border-radius: 6px;
    background: transparent;
    border: 1px solid #d3e6fb;
    color: #1f6fbf
}

.tg-people-controls {
    margin-top: 12px
}

.tg-control {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-top: 1px solid #eef6fb
}

.tg-control:first-child {
    border-top: 0
}

.tg-control label {
    font-size: 13px;
    color: #124058
}

.tg-qty {
    display: flex;
    align-items: center;
    gap: 8px
}

.tg-qty button {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    border: 1px solid #d3e6fb;
    background: #fff;
    color: #1f6fbf;
    font-weight: 700
}

.tg-qty input {
    width: 36px;
    text-align: center;
    border: 1px solid #e6f0fb;
    border-radius: 6px;
    padding: 6px;
    font-weight: 600
}

.tg-hotel-category {
    margin-top: 12px;
    padding: 12px;
    border: 1px solid #e7f0fb;
    border-radius: 8px;
    background: #fbfeff
}

.tg-hotel-title {
    font-weight: 700;
    color: #13455f;
    margin-bottom: 8px
}

.tg-radio-list {
    list-style: none;
    padding: 0;
    margin: 0
}

.tg-radio-list li {
    padding: 8px 0;
    border-top: 1px solid #f0f6fb
}

.tg-radio-list li:first-child {
    border-top: 0
}

.tg-radio-label {
    margin-left: 8px;
    color: #124058
}

.tg-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 12px
}

.tg-btn {
    display: inline-block;
    padding: 12px;
    border-radius: 6px;
    border: 0;
    cursor: pointer;
    font-weight: 700
}

.tg-btn-primary {
    background: #0b4fa0;
    color: #fff
}

.tg-btn-secondary {
    background: transparent;
    border: 1px solid #0b4fa0;
    color: #0b4fa0
}

@media (min-width:700px) {
    .travelgate-booking-widget {
        max-width: 420px
    }
}

.tg-price-card {
    padding-bottom: 10px
}