
/* City VIP Transfer - final mobile full-fit patch */
/* Amaç: tüm public/admin/partner/driver sayfalarında yatay taşmayı durdurmak. */

html,
body {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
}

*,
*::before,
*::after {
    box-sizing: border-box !important;
}

img,
svg,
video,
canvas,
iframe,
map,
embed,
object {
    max-width: 100% !important;
}

input,
select,
textarea,
button {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

a {
    overflow-wrap: anywhere;
}

/* Ana container ve kartlar */
.container,
.nav-wrap,
.nav-wide,
.section,
.hero,
.hero-inner,
.booking-card,
.form-card,
.soft-card,
.job-highlight,
.admin-main,
.admin-content,
.admin-table,
.table-wrap,
.responsive-table,
.payment-card,
.payment-container,
.route-container,
.ctv-route-hero,
.ctv-route-facts,
.ctv-seo-grid,
footer,
.site-footer,
.site-header,
main {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Public header güvenli mobil davranış */
.site-header {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: clip !important;
}

.site-header .nav-wrap,
.nav-wrap {
    width: 100% !important;
    max-width: 100vw !important;
    padding-left: clamp(12px, 4vw, 24px) !important;
    padding-right: clamp(12px, 4vw, 24px) !important;
}

.brand,
.brand-main {
    min-width: 0 !important;
}

.brand img {
    max-width: min(170px, 54vw) !important;
    height: auto !important;
}

.brand-domain {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

/* Formlar */
form,
.form-grid,
.booking-grid,
.booking-form,
.payment-form {
    max-width: 100% !important;
    min-width: 0 !important;
}

.form-grid,
.booking-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}

.field,
.form-field,
.input-wrap {
    min-width: 0 !important;
    max-width: 100% !important;
}

.field input,
.field select,
.field textarea,
.input-wrap input,
.input-wrap select,
.input-wrap textarea {
    width: 100% !important;
}

/* Tablo: sayfa değil tablo alanı scroll yapsın */
.table-wrap,
.responsive-table,
.admin-table,
.admin-table .table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
}

table {
    max-width: 100% !important;
}

.table-wrap table,
.responsive-table table,
.admin-table table {
    width: 100% !important;
    min-width: 720px;
}

/* Arka plan görseli mobilde dev kalmasın */
.page-public,
body.page-public,
.public-bg,
body {
    background-size: cover !important;
    background-position: center top !important;
}

/* Ödeme ve mail/success ekranları */
.payment-page,
.payment-box,
.success-note,
.danger-note,
.notice-card {
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
}

/* iPhone / Android ana mobil ayarlar */
@media (max-width: 768px) {
    html,
    body {
        width: 100vw !important;
        max-width: 100vw !important;
        overflow-x: hidden !important;
    }

    body {
        position: relative;
    }

    .container,
    .section .container,
    main > .container {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: 14px !important;
        padding-right: 14px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .booking-card,
    .form-card,
    .soft-card,
    .payment-card,
    .job-highlight,
    .notice-card,
    .success-note,
    .danger-note {
        width: 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        border-radius: 18px !important;
    }

    .booking-card {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .form-grid,
    .booking-grid,
    .grid-2,
    .grid-3,
    .ctv-route-facts,
    .ctv-seo-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .field,
    .field.full,
    .form-grid .full,
    .booking-grid .full {
        grid-column: 1 / -1 !important;
        width: 100% !important;
    }

    input,
    select,
    textarea,
    button,
    .btn {
        width: 100% !important;
        max-width: 100% !important;
    }

    .btn,
    button {
        white-space: normal !important;
    }

    .account-links,
    .reservation-access-actions,
    .guest-actions {
        width: 100% !important;
        max-width: 100% !important;
    }

    .account-links .btn,
    .reservation-access-actions .btn,
    .guest-actions .btn {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
    }

    .nav-menu {
        max-width: 100vw !important;
        overflow-x: hidden !important;
    }

    .lang-menu,
    .lang-dropdown {
        max-width: calc(100vw - 24px) !important;
        right: 12px !important;
        left: auto !important;
    }

    /* Admin / partner / driver panel mobil */
    .admin-main {
        width: 100% !important;
        max-width: 100vw !important;
        margin-left: 0 !important;
        padding-left: 10px !important;
        padding-right: 10px !important;
        overflow-x: hidden !important;
    }

    .admin-sidebar {
        max-width: 100vw !important;
        overflow-x: hidden !important;
    }

    .admin-table {
        overflow-x: auto !important;
    }

    .admin-table table,
    .table-wrap table {
        min-width: 760px !important;
    }

    /* Yolcu/bagaj stepper gibi yatay bileşenler */
    .stepper,
    .counter-control,
    .qty-control {
        width: 100% !important;
        max-width: 100% !important;
        display: grid !important;
        grid-template-columns: auto 1fr auto auto !important;
    }
}

@media (max-width: 430px) {
    .container,
    .section .container,
    main > .container {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .booking-card,
    .form-card,
    .soft-card,
    .payment-card {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .site-header .nav-wrap,
    .nav-wrap {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    .brand img {
        max-width: min(150px, 50vw) !important;
    }

    h1 {
        font-size: clamp(30px, 9vw, 42px) !important;
        line-height: 1.12 !important;
    }

    h2 {
        font-size: clamp(24px, 7vw, 34px) !important;
        line-height: 1.15 !important;
    }

    .table-wrap table,
    .admin-table table {
        min-width: 680px !important;
    }
}

@media (max-width: 390px) {
    .container,
    .section .container,
    main > .container {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    .booking-card,
    .form-card,
    .soft-card,
    .payment-card {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    .brand img {
        max-width: min(136px, 48vw) !important;
    }
}
