:root{
    --bg:#061126;
    --bg2:#0b1833;
    --card:#102043;
    --card2:#132750;
    --text:#f7f9ff;
    --muted:#a7b7d8;
    --line:rgba(255,255,255,.08);
    --blue:#3b82f6;
    --blue2:#2563eb;
    --green:#16a34a;
    --green2:#15803d;
    --red:#dc2626;
    --red2:#b91c1c;
    --shadow:0 18px 50px rgba(0,0,0,.35);
    --radius:24px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
    font-family:Arial,Helvetica,sans-serif;
    background:
        radial-gradient(circle at top left, rgba(59,130,246,.17), transparent 22%),
        radial-gradient(circle at top right, rgba(37,99,235,.12), transparent 18%),
        linear-gradient(180deg, #061126, #08142a 35%, #09152d 100%);
    color:var(--text);
}
a{text-decoration:none;color:inherit}
button,input,select{font:inherit}
button{cursor:pointer}
.page{min-height:100vh;display:flex;flex-direction:column}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}
.narrow{width:min(760px,calc(100% - 32px));margin:0 auto}

.header{position:sticky;top:0;z-index:10;background:rgba(6,17,38,.84);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.header__inner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 0}
.brand{display:flex;align-items:center;gap:14px}
.brand__logo{
    width:46px;height:46px;display:grid;place-items:center;border-radius:14px;
    background:linear-gradient(135deg,var(--blue),#7db3ff);font-weight:700;
    box-shadow:var(--shadow)
}
.brand__text strong{display:block}
.brand__text small{display:block;color:var(--muted);margin-top:4px}
.nav{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.nav a{padding:10px 14px;border-radius:12px;color:var(--muted)}
.nav a:hover,.nav a.active{background:rgba(255,255,255,.06);color:#fff}

.hero{padding:56px 0 28px}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:center}
.hero h1{font-size:54px;line-height:1.06;margin:14px 0 18px}
.lead{color:var(--muted);font-size:18px;line-height:1.7;max-width:720px}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
.stat{padding:16px 18px;border-radius:18px;background:rgba(255,255,255,.04);border:1px solid var(--line);min-width:135px}
.stat strong{display:block;font-size:28px}
.stat span{display:block;color:var(--muted);margin-top:6px}

.section{padding:28px 0 44px}
.section--muted{background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}
.section__head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px}
.chip{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(59,130,246,.16);border:1px solid rgba(59,130,246,.24);color:#cfe1ff;font-size:13px}

.card{
    background:linear-gradient(180deg,rgba(16,32,67,.96),rgba(11,24,51,.96));
    border:1px solid var(--line);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    padding:24px;
}
.card--soft{background:rgba(255,255,255,.03)}
.grid{display:grid;gap:18px}
.grid--2{grid-template-columns:1fr 1fr}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.feature__icon{font-size:28px;width:56px;height:56px;border-radius:16px;display:grid;place-items:center;background:rgba(59,130,246,.14);margin-bottom:16px}
.flight-card__bottom,.result__main,.ticket__top,.section__head,.actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.flight-card__bottom{margin-top:16px}
.button{
    display:inline-flex;align-items:center;justify-content:center;
    padding:14px 18px;border-radius:14px;border:none;color:#fff;font-weight:700;
    background:linear-gradient(135deg,var(--blue),var(--blue2));
    box-shadow:0 12px 28px rgba(37,99,235,.34);
    transition:.2s;
}
.button:hover{transform:translateY(-1px);filter:brightness(1.05)}
.button--small{padding:10px 14px;border-radius:12px;font-size:14px}
.button--ghost{background:rgba(255,255,255,.05);border:1px solid var(--line);box-shadow:none}

.form,.list{display:grid;gap:16px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:14px;color:#d6e2ff}
input,select{
    width:100%;
    padding:14px 14px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.10);
    background:#0f1c3a;
    color:#fff;
    outline:none;
}
input::placeholder{color:#8fa3c9}
input:focus,select:focus{border-color:rgba(125,179,255,.6);box-shadow:0 0 0 4px rgba(59,130,246,.12)}
select option{background:#0f1c3a;color:#fff}
.search-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:end}
.search-grid--admin{grid-template-columns:repeat(3,1fr)}
.field--button{justify-content:end}
.result{display:grid;gap:14px}
.result__actions{text-align:right}
.meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:14px}
.price{text-align:right}
.price strong{display:block;font-size:28px}
.price small{color:var(--muted)}
.details{display:grid;gap:10px;margin:18px 0}
.muted{color:var(--muted)}
.empty{text-align:center;padding:20px}
.demo-note{padding:16px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--line)}

.bus-card{padding:4px}
.bus-card__top{padding:14px;border-radius:16px;background:rgba(255,255,255,.06);text-align:center;color:#d7e5ff;margin-bottom:16px}
.seat-row{
    display:grid;
    grid-template-columns:64px 64px 26px 64px 64px;
    gap:12px;
    justify-content:center;
    align-items:center;
    margin-bottom:12px;
}
.seat-row--demo{grid-template-columns:64px 64px 26px 64px 64px}
.aisle{width:26px;height:64px}
.seat{
    width:64px;
    height:64px;
    min-width:64px;
    min-height:64px;
    max-width:64px;
    max-height:64px;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0;
    border:none;
    border-radius:16px;
    color:#fff;
    font-weight:700;
    font-size:22px;
    line-height:1;
    white-space:nowrap;
    text-align:center;
    overflow:hidden;
    box-sizing:border-box;
    aspect-ratio:1/1;
}
.seat.free{background:linear-gradient(180deg,var(--green),var(--green2))}
.seat.busy{background:linear-gradient(180deg,var(--red),var(--red2));cursor:not-allowed}
.seat.selected{background:linear-gradient(180deg,var(--blue),var(--blue2));box-shadow:0 10px 24px rgba(37,99,235,.35)}
.seat:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px)}
.legend{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);margin-top:18px}
.dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:8px}
.dot--free{background:#22c55e}
.dot--busy{background:#ef4444}
.dot--selected{background:#3b82f6}
.booking-box{display:grid;gap:8px;margin:16px 0}
.ajax-note{min-height:20px;margin-bottom:14px}
.badge-group{display:flex;gap:8px;flex-wrap:wrap}
.badge{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--line);font-size:13px}
.badge--reserved{background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.25)}
.badge--paid{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.25)}
.badge--cancelled{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.25)}
.ticket{display:grid;gap:14px}
.flash{margin-top:16px;padding:14px 16px;border-radius:16px}
.flash--success{background:rgba(34,197,94,.14);border:1px solid rgba(34,197,94,.3)}
.flash--error{background:rgba(239,68,68,.14);border:1px solid rgba(239,68,68,.3)}

.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.03)}
.table{width:100%;border-collapse:collapse;min-width:920px}
.table th,.table td{padding:16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.table th{background:rgba(255,255,255,.03)}
.table small{color:var(--muted)}
.admin-select{min-width:180px;margin-bottom:8px}
.stat{text-align:center}
.stat small{display:block;color:var(--muted)}
.stat strong{display:block;font-size:42px;margin-top:12px}

.footer{margin-top:auto;border-top:1px solid var(--line);background:rgba(0,0,0,.15);padding:30px 0}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:22px}
.footer__list{list-style:none;padding:0;margin:0;display:grid;gap:8px;color:var(--muted)}
.footer__list a{color:var(--muted)}

@media (max-width: 980px){
    .hero__grid,.grid--2,.grid--3,.grid--4,.footer__grid{grid-template-columns:1fr}
    .search-grid,.search-grid--admin{grid-template-columns:1fr}
    .hero h1{font-size:38px}
}
@media (max-width: 520px){
    .seat-row{grid-template-columns:54px 54px 18px 54px 54px;gap:8px}
    .seat{width:54px;height:54px;min-width:54px;min-height:54px;max-width:54px;max-height:54px;font-size:18px;border-radius:14px}
    .aisle{width:18px;height:54px}
}


/* ===== Final mobile, validation and payment fixes ===== */
.form small {
    display: block;
    margin-top: 6px;
    color: var(--muted);
    font-size: 13px;
}

.password-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: stretch;
}

.password-row input {
    min-width: 0;
}

.password-row .password-toggle {
    width: auto;
    min-width: 92px;
    padding-left: 12px;
    padding-right: 12px;
    white-space: nowrap;
}

.form-inner-grid {
    gap: 14px;
}

.footer a {
    color: inherit;
    text-decoration: none;
}

.footer a:hover {
    text-decoration: underline;
}

.ticket .actions,
.result__actions,
.hero__actions,
.actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.search-grid .field--button {
    display: flex;
    gap: 10px;
    align-items: end;
}

.seat {
    width: 48px;
    min-height: 48px;
    aspect-ratio: 1 / 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    overflow: hidden;
    text-align: center;
}

.bus-card {
    overflow-x: auto;
}

.seat-row {
    min-width: 310px;
}

.table-wrap {
    overflow-x: auto;
}

.card, .result, .ticket {
    overflow-wrap: anywhere;
}

@media (max-width: 860px) {
    .header__inner {
        align-items: flex-start;
        gap: 16px;
    }

    .brand {
        min-width: 180px;
        max-width: 45%;
    }

    .nav {
        flex: 1 1 auto;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px 12px;
        justify-items: start;
    }

    .nav .button {
        width: auto;
    }

    .grid--2,
    .grid--3,
    .grid--4,
    .hero__grid,
    .footer__grid {
        grid-template-columns: 1fr !important;
    }

    .search-grid {
        grid-template-columns: 1fr !important;
    }

    .search-grid .field--button {
        align-items: stretch;
    }

    .result__main,
    .ticket__top {
        grid-template-columns: 1fr !important;
        gap: 12px;
    }

    .meta {
        display: grid;
        grid-template-columns: 1fr;
        gap: 6px;
    }
}

@media (max-width: 560px) {
    .container {
        width: 100%;
        padding-left: 14px;
        padding-right: 14px;
    }

    .header__inner {
        flex-direction: row;
        padding-top: 14px;
        padding-bottom: 14px;
    }

    .brand {
        min-width: 0;
        max-width: 46%;
    }

    .brand__logo {
        width: 38px;
        height: 38px;
        flex: 0 0 38px;
    }

    .brand__text strong {
        font-size: 20px;
        line-height: 1.05;
    }

    .brand__text small {
        display: none;
    }

    .nav {
        grid-template-columns: 1fr 1fr;
        gap: 7px 10px;
    }

    .nav a {
        font-size: 15px;
        padding: 6px 0;
    }

    .nav .button {
        padding: 6px 8px;
        min-height: 34px;
    }

    h1 {
        font-size: 34px;
        line-height: 1.08;
    }

    h2 {
        font-size: 27px;
        line-height: 1.12;
    }

    .section {
        padding-top: 22px;
        padding-bottom: 22px;
    }

    .card {
        border-radius: 22px;
        padding: 20px;
    }

    .button,
    button {
        width: 100%;
    }

    .password-row {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .password-row .password-toggle {
        width: auto;
        min-width: 82px;
        font-size: 13px;
        padding-left: 10px;
        padding-right: 10px;
    }

    .search-grid .field--button,
    .ticket .actions,
    .result__actions,
    .hero__actions,
    .actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .seat {
        width: 44px;
        min-height: 44px;
        border-radius: 12px;
    }

    .seat-row {
        min-width: 290px;
        gap: 7px;
    }

    .footer {
        padding-bottom: 28px;
    }
}
