/* =============================================
   ТРАНСФЕР — Cinematic Design System
   ============================================= */
:root{
    --bg:#030308;--bg2:#0a0a14;--bg3:#0e0e1c;
    --glass:rgba(255,255,255,.04);--glass2:rgba(255,255,255,.07);
    --brd:rgba(255,255,255,.07);--brd2:rgba(255,255,255,.12);
    --text:#f4f4f8;--text2:rgba(255,255,255,.5);--text3:rgba(255,255,255,.25);
    --accent:#6366f1;--accent2:#818cf8;--accent3:#a78bfa;
    --green:#22c55e;--red:#ef4444;
    --r:12px;--r2:20px;--r3:28px;
    --ease:cubic-bezier(.4,0,.2,1);
    --spring:cubic-bezier(.34,1.56,.64,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Space Grotesk','Inter',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}
input,textarea{font:inherit;color:inherit;border:none;outline:none;background:none}
ul{list-style:none}
::selection{background:rgba(99,102,241,.35)}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:3px}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:140px 0;position:relative}
.section-dark{background:var(--bg2)}

/* glass */
.glass-card{
    background:var(--glass);
    border:1px solid var(--brd);
    backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
    border-radius:var(--r2);
}

/* ====== Preloader ====== */
.preloader{
    position:fixed;inset:0;background:var(--bg);z-index:10000;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
    transition:opacity .6s,visibility .6s;
}
.preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-wrap{display:flex;gap:6px;height:40px;align-items:end}
.loader-bar{width:4px;border-radius:2px;background:var(--accent);animation:loaderPulse .8s var(--ease) infinite alternate}
.loader-bar:nth-child(2){animation-delay:.15s;height:30px}
.loader-bar:nth-child(3){animation-delay:.3s;height:36px}
.loader-bar:nth-child(4){animation-delay:.45s;height:24px}
@keyframes loaderPulse{0%{height:12px;opacity:.4}100%{height:40px;opacity:1}}
.loader-name{font-size:.7rem;font-weight:700;letter-spacing:6px;color:var(--text3)}

/* ====== Header ====== */
.header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 0;transition:.3s var(--ease)}
.header.scrolled{padding:10px 0;background:rgba(3,3,8,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--brd)}
.nav{display:flex;align-items:center;gap:12px}
.logo{display:flex;align-items:center;gap:10px;margin-right:auto;z-index:10}
.logo-img{width:38px;height:38px;border-radius:10px;object-fit:cover}
.logo-label{font-size:1.1rem;font-weight:700}
.nav-menu{display:flex;gap:4px;margin:0 auto}
.nav-link{padding:8px 14px;border-radius:8px;font-size:.85rem;font-weight:500;color:var(--text2);transition:.2s}
.nav-link:hover{color:var(--text);background:rgba(255,255,255,.05)}
.nav-right{display:flex;gap:8px}

/* btns */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;border-radius:10px;font-weight:600;font-size:.875rem;transition:.25s var(--ease);white-space:nowrap}
.btn-accent{background:linear-gradient(135deg,var(--accent),#7c3aed);color:#fff;box-shadow:0 2px 20px rgba(99,102,241,.25)}
.btn-accent:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(99,102,241,.4)}
.btn-ghost{color:var(--text2);border:1px solid var(--brd)}
.btn-ghost:hover{color:var(--text);border-color:var(--brd2);background:rgba(255,255,255,.04)}
.btn-white{background:#fff;color:#0a0a14;font-weight:700;padding:14px 32px;border-radius:var(--r)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,255,255,.12)}
.btn-search{width:100%;padding:14px;border-radius:var(--r);background:linear-gradient(135deg,var(--accent),#7c3aed);color:#fff;font-weight:700;font-size:.95rem;box-shadow:0 4px 24px rgba(99,102,241,.3)}
.btn-search:hover{box-shadow:0 8px 32px rgba(99,102,241,.5);transform:translateY(-1px)}
.btn-full{width:100%}
.burger{display:none;flex-direction:column;gap:5px;width:24px;z-index:10}
.burger span{width:100%;height:2px;background:var(--text);border-radius:2px;transition:.3s}
.burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ====== Hero ====== */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;padding:100px 0 60px;overflow:hidden}

.hero-video-wrap{position:absolute;inset:0;z-index:0}
.hero-video{width:100%;height:100%;object-fit:cover;display:block}
.hero-overlay{
    position:absolute;inset:0;
    background:
        linear-gradient(to right,rgba(3,3,8,.92) 0%,rgba(3,3,8,.7) 40%,rgba(3,3,8,.5) 70%,rgba(3,3,8,.75) 100%),
        linear-gradient(to bottom,rgba(3,3,8,.3) 0%,transparent 30%,transparent 70%,rgba(3,3,8,1) 100%);
}
.hero-grain{
    position:absolute;inset:0;
    background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
    opacity:.5;pointer-events:none;
}

.hero-body{position:relative;z-index:2;display:grid;grid-template-columns:1fr 400px;gap:56px;align-items:center}
.hero-left{max-width:580px}

.hero-chip{
    display:inline-flex;align-items:center;gap:10px;
    padding:7px 18px;border-radius:100px;
    background:rgba(255,255,255,.06);border:1px solid var(--brd);
    font-size:.78rem;font-weight:600;color:var(--text2);
    margin-bottom:28px;backdrop-filter:blur(8px);
}
.chip-live{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px rgba(34,197,94,.5);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{opacity:.6;box-shadow:0 0 0 8px transparent}}

.hero-h1{font-size:clamp(2.6rem,5.5vw,4.4rem);font-weight:800;line-height:1.05;letter-spacing:-2px;margin-bottom:20px}
.hero-accent-word{
    background:linear-gradient(135deg,#818cf8,#c084fc,#f472b6,#818cf8);
    background-size:300% 300%;
    -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
    animation:shineGrad 4s ease infinite;
}
@keyframes shineGrad{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Word-by-word reveal */
.anim-word{display:inline-block;opacity:0;transform:translateY(40px) rotateX(20deg);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.anim-word.show{opacity:1;transform:translateY(0) rotateX(0)}
.anim-reveal{opacity:0;transform:translateY(32px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.anim-reveal.show{opacity:1;transform:translateY(0)}

.hero-sub{font-size:1.05rem;color:var(--text2);line-height:1.75;margin-bottom:36px;max-width:460px}

.hero-nums{display:flex;gap:32px}
.hero-num{display:flex;flex-direction:column}
.hero-num strong{font-size:1.7rem;font-weight:800;background:linear-gradient(135deg,var(--accent),var(--accent3));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-num span{font-size:.75rem;color:var(--text3);margin-top:2px}

/* Search Card */
.search-card{padding:0;overflow:hidden;box-shadow:0 12px 60px rgba(0,0,0,.5),0 0 100px rgba(99,102,241,.06)}
.s-tabs{display:flex;border-bottom:1px solid var(--brd)}
.s-tab{flex:1;padding:15px;font-size:.82rem;font-weight:600;color:var(--text3);transition:.2s;position:relative}
.s-tab.active{color:var(--text)}
.s-tab.active::after{content:'';position:absolute;bottom:-1px;left:20%;right:20%;height:2px;background:linear-gradient(90deg,var(--accent),#a855f7);border-radius:2px}
.s-tab:hover:not(.active){color:var(--text2)}
.s-form{padding:20px}

.s-field-row{position:relative;display:flex;gap:12px;align-items:stretch}
.s-fields{flex:1;display:flex;flex-direction:column;gap:8px}
.s-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;position:absolute;left:0;z-index:2}
.s-dot-g{top:18px;background:var(--green);box-shadow:0 0 8px rgba(34,197,94,.4)}
.s-dot-r{bottom:18px;background:var(--red);box-shadow:0 0 8px rgba(239,68,68,.4)}
.s-dashes{position:absolute;left:4px;top:32px;bottom:32px;width:1.5px;border-left:1.5px dashed rgba(255,255,255,.1)}

.s-input-wrap{position:relative}
.s-input-wrap input{
    width:100%;padding:13px 16px 13px 24px;
    background:rgba(255,255,255,.04);border:1px solid var(--brd);
    border-radius:var(--r);font-size:.92rem;transition:.2s;
}
.s-input-wrap input:focus{border-color:var(--accent);background:rgba(255,255,255,.07)}
.s-input-wrap input::placeholder{color:var(--text3)}

.swap-btn{
    width:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
    border-radius:8px;background:rgba(255,255,255,.04);border:1px solid var(--brd);
    color:var(--text3);transition:.25s var(--ease);
}
.swap-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(180deg)}

.s-meta{display:flex;gap:8px;margin:12px 0 16px}
.s-meta-item{
    flex:1;display:flex;align-items:center;gap:8px;
    padding:10px 12px;background:rgba(255,255,255,.04);
    border:1px solid var(--brd);border-radius:var(--r);color:var(--text2);font-size:.88rem;
}
.s-meta-item input[type="date"]{flex:1;color:var(--text);background:none;font-size:.88rem}
.s-meta-item input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.35;cursor:pointer}
.pm{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.06);font-size:.9rem;font-weight:600;color:var(--text2);transition:.2s}
.pm:hover{background:var(--accent);color:#fff}
#pc{font-weight:700;min-width:14px;text-align:center}

.suggestions{
    position:absolute;top:calc(100% + 4px);left:0;right:0;
    background:var(--bg3);border:1px solid var(--brd);border-radius:var(--r);
    z-index:100;display:none;box-shadow:0 12px 40px rgba(0,0,0,.6);
    overflow:hidden;max-height:240px;overflow-y:auto;
}
.suggestions.on{display:block;animation:popUp .2s var(--ease)}
@keyframes popUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.sug{padding:11px 14px;cursor:pointer;font-size:.88rem;display:flex;justify-content:space-between;transition:.15s}
.sug:hover{background:rgba(99,102,241,.08)}
.sug small{color:var(--text3)}

/* Hero bottom */
.hero-bottom{position:absolute;bottom:24px;left:50%;transform:translateX(-50%)}
.hero-scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--accent2),transparent);animation:scrollP 2s ease-in-out infinite}
@keyframes scrollP{0%,100%{opacity:.8;height:48px}50%{opacity:.2;height:28px}}

/* ====== Ticker ====== */
.ticker{padding:18px 0;border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);overflow:hidden;background:rgba(255,255,255,.01)}
.ticker-track{display:flex;align-items:center;gap:28px;animation:scroll 28s linear infinite;width:max-content}
.ticker-track span{font-size:.78rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:3px;white-space:nowrap}
.ticker-track i{width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ====== Sections ====== */
.sec-head{text-align:center;margin-bottom:56px}
.sec-label{
    display:inline-block;padding:5px 14px;border-radius:100px;
    background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.15);
    font-size:.72rem;font-weight:700;color:var(--accent2);
    text-transform:uppercase;letter-spacing:2.5px;margin-bottom:14px;
}
.sec-title{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;letter-spacing:-1px}

/* ====== Routes ====== */
.routes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.route{border-radius:var(--r2);overflow:hidden;position:relative;min-height:170px;display:flex;cursor:pointer;transition:.35s var(--ease)}
.route:hover{transform:translateY(-5px) scale(1.01)}
.route.big{grid-column:span 2;min-height:220px}
.route-grad{position:absolute;inset:0;background:var(--g);transition:opacity .5s var(--ease)}
.route-grad::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65),transparent 55%)}

.route-vid{
    position:absolute;inset:0;
    width:100%;height:100%;object-fit:cover;
    opacity:0;
    transform:scale(1.1);
    transition:opacity .6s var(--ease),transform 4s var(--ease);
    z-index:0;
    pointer-events:none;
}
.route:hover .route-vid{opacity:1;transform:scale(1)}
.route:hover .route-grad{opacity:.25}

.route-body{position:relative;z-index:2;padding:22px;display:flex;flex-direction:column;justify-content:flex-end;width:100%;gap:6px}
.route-body::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.2) 40%,transparent 100%);
    z-index:-1;
    opacity:0;transition:opacity .5s var(--ease);
    border-radius:inherit;
}
.route:hover .route-body::before{opacity:1}

.route-tag{position:absolute;top:14px;left:14px;padding:4px 12px;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);border-radius:100px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;z-index:2}

.route-play-hint{
    position:absolute;top:14px;right:14px;
    display:flex;align-items:center;gap:6px;
    padding:5px 12px;
    background:rgba(0,0,0,.35);
    backdrop-filter:blur(6px);
    border-radius:100px;
    font-size:.68rem;font-weight:600;color:rgba(255,255,255,.7);
    transition:opacity .3s;
    z-index:2;
}
.route:hover .route-play-hint{opacity:0}

.route h3{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:6px;flex-wrap:wrap;transition:transform .4s var(--ease)}
.route:hover h3{transform:translateY(-4px)}
.route h3 em{font-style:normal}
.route .arr{color:rgba(255,255,255,.4);font-size:.9rem}
.route p{font-size:.78rem;color:rgba(255,255,255,.6);transition:transform .4s var(--ease) .05s}
.route:hover p{transform:translateY(-2px)}
.route p b{color:#fff}

/* ====== Steps ====== */
.steps{display:flex;align-items:flex-start;justify-content:center;gap:0}
.step{text-align:center;padding:32px 24px;max-width:260px;position:relative}
.step-n{
    position:absolute;top:-12px;left:50%;transform:translateX(-50%);
    padding:4px 14px;border-radius:100px;
    background:linear-gradient(135deg,var(--accent),#7c3aed);
    font-size:.72rem;font-weight:800;color:#fff;
}
.step-ico{
    width:56px;height:56px;margin:12px auto 18px;
    display:flex;align-items:center;justify-content:center;
    border-radius:14px;background:rgba(99,102,241,.1);color:var(--accent2);
    transition:.3s var(--ease);
}
.step:hover .step-ico{background:linear-gradient(135deg,var(--accent),#7c3aed);color:#fff;transform:scale(1.08)}
.step h3{font-size:.95rem;font-weight:700;margin-bottom:6px}
.step p{font-size:.82rem;color:var(--text2);line-height:1.5}
.step-arrow{display:flex;align-items:center;padding-top:60px;color:var(--text3)}

/* ====== Features ====== */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.feat{padding:28px;transition:.3s var(--ease);position:relative;overflow:hidden}
.feat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--c,var(--accent)),transparent);opacity:0;transition:.3s}
.feat:hover{transform:translateY(-3px);border-color:var(--brd2)}
.feat:hover::before{opacity:1}
.feat-icon{
    width:44px;height:44px;display:flex;align-items:center;justify-content:center;
    border-radius:var(--r);background:color-mix(in srgb,var(--c,var(--accent)) 12%,transparent);
    color:var(--c,var(--accent));margin-bottom:18px;transition:.3s;
}
.feat:hover .feat-icon{transform:scale(1.08)}
.feat h3{font-size:.95rem;font-weight:700;margin-bottom:6px}
.feat p{font-size:.82rem;color:var(--text2);line-height:1.55}

/* ====== Trips ====== */
.trips-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.trip{
    display:flex;align-items:center;gap:14px;
    padding:18px 20px;background:var(--glass);border:1px solid var(--brd);
    border-radius:var(--r);cursor:pointer;transition:.25s var(--ease);
}
.trip:hover{border-color:var(--accent);background:rgba(99,102,241,.04);transform:translateY(-2px)}
.trip-info{flex:1;min-width:0}
.trip-cities{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.88rem;margin-bottom:3px}
.trip-cities .td{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.trip-cities .td.g{background:var(--green)}.trip-cities .td.r{background:var(--red)}
.trip-cities .tl{width:24px;height:1px;background:var(--brd)}
.trip-cities span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trip-sub{font-size:.75rem;color:var(--text3)}
.trip-drv{display:flex;align-items:center;gap:8px}
.trip-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;color:#fff;flex-shrink:0}
.trip-dn{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trip-dr{font-size:.72rem;color:#fbbf24}
.trip-pr{font-size:1.1rem;font-weight:800;color:var(--accent2);white-space:nowrap;margin-left:auto}

/* ====== CTA ====== */
.cta-wrap{padding:0 0 140px}
.cta-box{position:relative;background:linear-gradient(135deg,var(--accent),#7c3aed,#a855f7);border-radius:var(--r3);overflow:hidden;padding:64px}
.cta-blob{position:absolute;width:350px;height:350px;border-radius:50%;background:rgba(255,255,255,.07);filter:blur(60px);top:-150px;right:-50px;animation:blobFloat 10s ease-in-out infinite}
.cta-blob-2{width:250px;height:250px;bottom:-120px;left:-60px;top:auto;right:auto;animation-delay:3s}
@keyframes blobFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(30px,-30px)}}
.cta-content{position:relative;z-index:1;max-width:560px}
.cta-content h2{font-size:2.2rem;font-weight:800;margin-bottom:12px;letter-spacing:-1px}
.cta-content p{font-size:1rem;color:rgba(255,255,255,.8);line-height:1.7;margin-bottom:24px}
.cta-stats{display:flex;gap:24px;margin-bottom:28px}
.cta-st strong{display:block;font-size:1.6rem;font-weight:800}
.cta-st span{font-size:.78rem;color:rgba(255,255,255,.55)}

/* ====== Reviews ====== */
.reviews-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rev{padding:26px;display:flex;flex-direction:column;transition:.3s var(--ease)}
.rev:hover{transform:translateY(-3px);border-color:var(--brd2)}
.rev-accent{background:rgba(99,102,241,.07)!important;border-color:rgba(99,102,241,.15)!important}
.rev-stars{color:#fbbf24;font-size:.85rem;letter-spacing:2px;margin-bottom:12px}
.rev p{font-size:.85rem;color:var(--text2);line-height:1.65;flex:1;font-style:italic;margin-bottom:18px}
.rev-who{display:flex;align-items:center;gap:10px}
.rev-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff;flex-shrink:0}
.rev-who b{font-size:.88rem}
.rev-who small{color:var(--text3);font-size:.73rem}

/* ====== Contact ====== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.contact-info .sec-title{text-align:left;margin-bottom:8px}
.contact-info>p{color:var(--text2);margin-bottom:24px;font-size:1rem}
.c-links{display:flex;flex-direction:column;gap:10px}
.c-link{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--glass);border:1px solid var(--brd);border-radius:var(--r);font-size:.88rem;color:var(--text2);transition:.2s}
.c-link:hover{border-color:var(--accent);color:var(--text);transform:translateX(4px)}
.c-link svg{color:var(--accent2);flex-shrink:0}

.contact-form{padding:32px;display:flex;flex-direction:column;gap:12px}
.form-2col{display:flex;gap:10px}
.contact-form input,.contact-form textarea{
    width:100%;padding:12px 14px;background:rgba(255,255,255,.04);
    border:1px solid var(--brd);border-radius:var(--r);font-size:.88rem;resize:vertical;transition:.2s;
}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--accent);background:rgba(255,255,255,.06)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text3)}

/* ====== Footer ====== */
.footer{border-top:1px solid var(--brd);padding:64px 0 28px}
.f-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
.f-brand p{color:var(--text2);font-size:.82rem;margin:12px 0 18px;line-height:1.6}
.f-socials{display:flex;gap:8px}
.f-socials a{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--glass);border:1px solid var(--brd);color:var(--text3);transition:.2s}
.f-socials a:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)}
.f-col{display:flex;flex-direction:column;gap:9px}
.f-col h4{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px;color:var(--text)}
.f-col a{font-size:.82rem;color:var(--text2);transition:.2s}
.f-col a:hover{color:var(--accent2)}
.f-bottom{display:flex;justify-content:space-between;padding-top:20px;border-top:1px solid var(--brd);font-size:.78rem;color:var(--text3)}

/* ====== Modal ====== */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.3s}
.modal-bg.on{opacity:1;visibility:visible}
.modal{padding:32px;max-width:400px;width:90%;transform:scale(.95);transition:.3s var(--ease);position:relative}
.modal-bg.on .modal{transform:scale(1)}
.modal h2{font-size:1.5rem;font-weight:800;margin-bottom:4px}
.modal-desc{color:var(--text2);font-size:.88rem;margin-bottom:18px}
.modal-x{position:absolute;top:12px;right:12px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.3rem;color:var(--text3);transition:.2s}
.modal-x:hover{background:rgba(255,255,255,.06);color:var(--text)}
.modal form{display:flex;flex-direction:column;gap:10px}
.modal input{width:100%;padding:12px 14px;background:rgba(255,255,255,.04);border:1px solid var(--brd);border-radius:var(--r);font-size:.88rem;transition:.2s}
.modal input:focus{border-color:var(--accent)}
.modal input::placeholder{color:var(--text3)}
.modal .form-2col{display:flex;gap:8px}
.modal .form-2col input{flex:1}

/* ====== Results ====== */
.results{position:fixed;top:0;right:-500px;width:460px;height:100vh;background:var(--bg3);border-left:1px solid var(--brd);z-index:1500;transition:.4s var(--ease);box-shadow:-10px 0 50px rgba(0,0,0,.5);overflow-y:auto}
.results.on{right:0}
.results-top{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--brd);position:sticky;top:0;background:var(--bg3);z-index:1}
.results-top h3{font-size:1.05rem;font-weight:700}
.results-body{padding:14px 22px}
.res{padding:16px;margin-bottom:10px;background:var(--glass);border:1px solid var(--brd);border-radius:var(--r);cursor:pointer;transition:.2s}
.res:hover{border-color:var(--accent);background:rgba(99,102,241,.04)}
.res-route{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.92rem;margin-bottom:8px}
.res-d{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.res-d.g{background:var(--green)}.res-d.r{background:var(--red)}
.res-l{flex:1;height:1px;background:var(--brd);max-width:40px}
.res-mid{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.res-time{font-size:.78rem;color:var(--text3)}
.res-price{font-size:1.1rem;font-weight:800;color:var(--accent2)}
.res-drv{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid var(--brd)}
.res-dav{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.65rem;color:#fff}
.res-dn{font-size:.82rem;font-weight:600}
.res-dr{font-size:.75rem;color:#fbbf24;margin-left:auto}

/* ====== Toasts ====== */
.toasts{position:fixed;top:20px;right:20px;z-index:3000;display:flex;flex-direction:column;gap:8px}
.toast{padding:13px 18px;min-width:260px;background:var(--bg3);border:1px solid var(--brd);border-radius:var(--r);box-shadow:0 8px 30px rgba(0,0,0,.5);font-size:.88rem;font-weight:500;animation:tIn .4s var(--spring)}
.toast.out{animation:tOut .3s var(--ease) forwards}
.toast-ok{border-left:3px solid var(--green)}
.toast-err{border-left:3px solid var(--red)}
@keyframes tIn{from{opacity:0;transform:translateX(80px)}to{opacity:1;transform:translateX(0)}}
@keyframes tOut{to{opacity:0;transform:translateX(80px)}}

/* ====== Scroll anim ====== */
[data-animate="card"]{opacity:0;transform:translateY(28px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-animate="card"].show{opacity:1;transform:translateY(0)}

@media(max-width:768px){
    [data-animate="card"],
    .anim-reveal,
    .anim-word{
        opacity:1!important;
        transform:none!important;
    }
}

/* ====== Responsive ====== */

@media(max-width:1024px){
    .hero-body{grid-template-columns:1fr;gap:36px}
    .hero-left{max-width:100%;text-align:center}
    .hero-sub{margin:0 auto 36px}
    .hero-nums{justify-content:center}
    .search-card{max-width:440px;margin:0 auto}
    .routes-grid{grid-template-columns:repeat(2,1fr)}
    .route.big{grid-column:span 2}
    .reviews-row{grid-template-columns:repeat(2,1fr)}
    .f-top{grid-template-columns:1fr 1fr;gap:28px}
}

@media(max-width:768px){
    .section{padding:80px 0}
    .sec-head{margin-bottom:40px}

    /* Nav */
    .nav-menu,.nav-right{display:none}
    .nav-menu.active{
        display:flex;position:fixed;inset:0;
        background:rgba(3,3,8,.97);
        flex-direction:column;align-items:center;justify-content:center;
        gap:8px;z-index:5;
        backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    }
    .nav-right.active{
        display:flex;position:fixed;bottom:32px;left:20px;right:20px;
        z-index:6;gap:10px;
    }
    .nav-right.active .btn{flex:1;padding:14px;font-size:.95rem}
    .nav-link{font-size:1.3rem;padding:14px 24px;font-weight:600}
    .burger{display:flex}

    /* Hero */
    .hero{min-height:auto;padding:100px 0 60px}
    .hero-h1{font-size:2rem;letter-spacing:-1px}
    .hero-sub{font-size:.95rem;margin-bottom:28px}
    .hero-chip{font-size:.72rem;padding:5px 14px}
    .hero-nums{flex-direction:row;gap:20px;flex-wrap:wrap;justify-content:center}
    .counter-value{font-size:1.4rem}
    .counter-sep{display:none}
    .hero-num span{font-size:.68rem}
    .hero-right{width:100%}
    .search-card{max-width:100%;margin:0}
    .hero-bottom{display:none}

    /* Ticker */
    .ticker{padding:14px 0}
    .ticker-track span{font-size:.65rem;letter-spacing:2px}
    .ticker-track i{width:3px;height:3px}
    .ticker-track{gap:20px}

    /* Routes */
    .routes-grid{grid-template-columns:1fr;gap:12px}
    .route.big{grid-column:span 1;min-height:180px}
    .route{min-height:150px}
    .route-play-hint{display:none}
    .route-vid{opacity:1;transform:scale(1)}
    .route-grad{opacity:.35}
    .route-body::before{opacity:1}
    .route h3{font-size:.95rem}

    /* Steps */
    .steps{flex-direction:column;align-items:center;gap:16px}
    .step{max-width:100%;width:100%}
    .step-arrow{transform:rotate(90deg);padding:0;margin:0;height:24px}
    .step-arrow svg{width:20px;height:20px}

    /* Features */
    .features-grid{grid-template-columns:1fr;gap:10px}
    .feat{padding:22px}

    /* Trips */
    .trips-list{grid-template-columns:1fr;gap:10px}
    .trip{flex-wrap:wrap;gap:10px;padding:16px}
    .trip-info{width:100%}
    .trip-drv{flex:1}
    .trip-pr{font-size:1rem}

    /* Reviews */
    .reviews-row{grid-template-columns:1fr;gap:10px}
    .rev{padding:22px}

    /* CTA */
    .cta-box{padding:36px 22px}
    .cta-content h2{font-size:1.6rem}
    .cta-content p{font-size:.9rem}
    .cta-stats{flex-direction:row;gap:16px;flex-wrap:wrap}
    .cta-st strong{font-size:1.3rem}

    /* Contact */
    .contact-grid{grid-template-columns:1fr;gap:28px}
    .contact-info .sec-title{text-align:center}
    .contact-info{text-align:center}
    .c-links{align-items:stretch}
    .contact-form{padding:24px}

    /* Footer */
    .f-top{grid-template-columns:1fr;text-align:center;gap:28px}
    .f-socials{justify-content:center}
    .f-bottom{flex-direction:column;gap:4px;text-align:center}

    /* Results panel */
    .results{width:100%;right:-100%}
    .form-2col{flex-direction:column;gap:10px}

    /* Toast */
    .toasts{left:16px;right:16px;top:auto;bottom:20px}
    .toast{min-width:auto;width:100%;font-size:.82rem}

    /* Modal */
    .modal{padding:24px;max-width:100%;width:calc(100% - 32px)}
}

@media(max-width:480px){
    .container{padding:0 14px}
    .hero{padding:90px 0 50px}
    .hero-h1{font-size:1.7rem;letter-spacing:-.5px}
    .hero-sub{font-size:.88rem;line-height:1.65}
    .hero-chip{margin-bottom:20px;font-size:.68rem}
    .hero-nums{gap:16px}
    .counter-value{font-size:1.2rem}
    .s-meta{flex-direction:column;gap:8px}
    .s-form{padding:16px}
    .s-tabs .s-tab{padding:12px;font-size:.78rem}

    .sec-title{font-size:1.5rem}
    .sec-label{font-size:.65rem;padding:4px 12px;letter-spacing:2px}

    .route{min-height:140px}
    .route.big{min-height:160px}
    .route-body{padding:16px}
    .route h3{font-size:.88rem}
    .route p{font-size:.72rem}
    .route-tag{font-size:.6rem;padding:3px 10px;top:10px;left:10px}

    .step{padding:24px 18px}
    .feat{padding:18px}
    .feat-icon{width:40px;height:40px;margin-bottom:14px}
    .feat h3{font-size:.88rem}
    .feat p{font-size:.78rem}

    .trip{padding:14px}
    .trip-cities{font-size:.82rem}
    .trip-sub{font-size:.7rem}
    .trip-pr{font-size:.95rem}

    .rev{padding:18px}
    .rev p{font-size:.82rem}

    .cta-box{padding:28px 18px}
    .cta-content h2{font-size:1.4rem}
    .cta-stats{gap:12px}
    .cta-st strong{font-size:1.1rem}
    .cta-st span{font-size:.7rem}

    .c-link{padding:11px 14px;font-size:.82rem}
    .contact-form{padding:20px}
    .contact-form input,.contact-form textarea{padding:11px 12px;font-size:.85rem}

    .f-col h4{font-size:.7rem}
    .f-col a{font-size:.78rem}
    .f-brand p{font-size:.78rem}
}

/* ====== Role tabs ====== */
.role-tabs{display:flex;gap:0;border-radius:var(--r);overflow:hidden;border:1px solid var(--brd);margin-bottom:14px}
.role-tab{flex:1;padding:10px;font-size:.85rem;font-weight:600;color:var(--text3);background:transparent;transition:.2s}
.role-tab.active{background:var(--accent);color:#fff}
.role-tab:hover:not(.active){background:rgba(255,255,255,.04);color:var(--text2)}
#driverFields{display:flex;flex-direction:column;gap:10px}
#driverFields input{width:100%;padding:12px 14px;background:rgba(255,255,255,.04);border:1px solid var(--brd);border-radius:var(--r);font-size:.88rem}
#driverFields input:focus{border-color:var(--accent)}
#driverFields input::placeholder{color:var(--text3)}

/* Profile modal */
.profile-card{padding:16px;background:var(--glass);border:1px solid var(--brd);border-radius:var(--r);margin-bottom:10px}
.profile-card h4{font-size:.82rem;font-weight:700;color:var(--text2);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.profile-item{display:flex;justify-content:space-between;padding:6px 0;font-size:.88rem;border-bottom:1px solid var(--brd)}
.profile-item:last-child{border:none}
.profile-item span:first-child{color:var(--text2)}
.booking-card{padding:12px;background:var(--glass);border:1px solid var(--brd);border-radius:var(--r);margin-bottom:8px;font-size:.85rem}
.booking-card .bc-route{font-weight:700;margin-bottom:4px}
.booking-card .bc-meta{color:var(--text2);font-size:.78rem}
.booking-status{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:700}
.booking-status.confirmed{background:rgba(34,197,94,.15);color:#22c55e}
.booking-status.pending{background:rgba(251,191,36,.15);color:#fbbf24}
.booking-status.cancelled{background:rgba(239,68,68,.15);color:#ef4444}
.bc-cancel{padding:4px 10px;margin-top:6px;font-size:.75rem;color:var(--red);background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.15);border-radius:6px;cursor:pointer}
