:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:#17191f;background:#f4f1ea}*{box-sizing:border-box}body{min-height:100vh;margin:0;background:#eee8dc}.passenger-app{position:relative;min-height:100vh;overflow:hidden}.map-layer{position:absolute;inset:0;background:linear-gradient(135deg,#f6f1e8,#e8edf1)}.map-layer:before,.map-layer:after{content:"";position:absolute;border-radius:999px;background:#d8dee3}.map-layer:before{width:560px;height:88px;left:-90px;top:230px;transform:rotate(-28deg)}.map-layer:after{width:640px;height:95px;right:-120px;top:420px;transform:rotate(22deg)}.map-road{position:absolute;border-radius:999px;background:#fff;box-shadow:0 0 0 1px #dfe3e7}.road-a{width:760px;height:56px;left:-120px;top:130px;transform:rotate(12deg)}.road-b{width:620px;height:48px;right:-110px;bottom:210px;transform:rotate(-18deg)}.road-c{width:52px;height:760px;left:44%;top:-120px;transform:rotate(17deg)}.passenger-topbar{position:relative;z-index:5;display:flex;justify-content:space-between;gap:12px;padding:18px}.cabinet-button,.location-button{height:42px;border:0;border-radius:14px;background:#fff;color:#17191f;font-size:12px;font-weight:850;box-shadow:0 10px 30px rgba(30,34,43,.12)}.cabinet-button{padding:0 16px}.location-button{width:42px}.city-warning{position:relative;z-index:6;width:min(520px,calc(100% - 36px));margin:0 auto;padding:14px 16px;border:1px solid #f0d27a;border-radius:16px;background:#fff8df;box-shadow:0 14px 40px rgba(30,34,43,.1)}.city-warning strong,.city-warning span,.city-warning a{display:block}.city-warning strong{font-size:13px}.city-warning span{margin-top:5px;color:#70695a;font-size:11px}.city-warning a{margin-top:10px;color:#17191f;font-size:11px;font-weight:900}.ride-sheet{position:fixed;z-index:7;left:50%;bottom:18px;width:min(520px,calc(100% - 28px));padding:10px 18px 18px;border:1px solid #e4e5e8;border-radius:24px;background:rgba(255,255,255,.96);box-shadow:0 24px 80px rgba(30,34,43,.2);transform:translateX(-50%);transition:.25s ease}.ride-sheet.expanded{top:18px;bottom:18px;overflow:auto}.ride-sheet.map-picking{transform:translate(-50%,calc(100% + 40px));pointer-events:none}.sheet-handle{width:42px;height:4px;margin:0 auto 16px;border-radius:99px;background:#d8dbe0}.kicker{margin:0;color:#9b7600;font-size:10px;font-weight:900;letter-spacing:.16em;text-transform:uppercase}.ride-sheet h1{margin:6px 0 16px;font-size:28px}.ride-form{display:grid;gap:12px}.ride-form label{display:grid;gap:7px;color:#737984;font-size:10px;font-weight:850}.ride-form input{height:48px;padding:0 14px;border:1px solid #dfe2e6;border-radius:13px;background:#fff;font:inherit}.ride-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ride-actions button,.order-button,.guest-help button{height:44px;border:0;border-radius:12px;background:#f1f2f4;color:#17191f;font-size:11px;font-weight:850}.order-button{background:#ffc400}.order-button:disabled{background:#e2e4e8;color:#8c929b}.guest-help{margin-top:14px;padding:15px;border-radius:16px;background:#fff8df}.guest-help h2{margin:0;font-size:15px}.guest-help p{margin:7px 0 12px;color:#726d62;font-size:11px}.dispatcher-phone-list{display:grid;gap:8px;margin-top:12px}.dispatcher-phone-list a,.dispatcher-phone-list span{padding:10px 12px;border-radius:10px;background:#fff;color:#17191f;font-size:11px;font-weight:850;text-decoration:none}.passenger-cabinet{position:fixed;z-index:20;top:18px;right:18px;width:min(360px,calc(100% - 36px));padding:20px;border:1px solid #e2e4e8;border-radius:22px;background:#fff;box-shadow:0 24px 80px rgba(30,34,43,.2)}.profile-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:22px}.profile-nav span{font-size:13px;font-weight:900}.profile-back{height:36px;padding:0 12px;border:0;border-radius:12px;background:#f1f2f4;color:#17191f;font-size:12px;font-weight:850}.cabinet-profile{display:flex;gap:12px;align-items:center}.cabinet-profile>span{width:48px;height:48px;display:grid;place-items:center;border-radius:14px;background:#ffc400;font-weight:900}.cabinet-profile strong,.cabinet-profile small{display:block}.cabinet-profile small{margin-top:4px;color:#8b919a}.cabinet-list{display:grid;gap:9px;margin-top:22px}.cabinet-list button{display:flex;justify-content:space-between;gap:14px;padding:13px;border:1px solid #e6e8eb;border-radius:12px;background:#fff;text-align:left;font-weight:850}.cabinet-list small{color:#8b919a;font-weight:700}@media(min-width:900px){.ride-sheet{left:auto;right:38px;transform:none}.ride-sheet.expanded{width:520px}.ride-sheet.map-picking{transform:translateX(calc(100% + 80px))}.passenger-topbar{padding:26px 38px}}
.fleet-choice{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px;border:1px solid #e3e5e9;border-radius:14px;background:#fff}.fleet-choice small,.fleet-choice strong{display:block}.fleet-choice small{color:#8b919a;font-size:9px}.fleet-choice strong{margin-top:4px;font-size:12px}.fleet-choice button{padding:8px 10px;border:0;border-radius:9px;background:#17191f;color:#ffc400;font-size:10px;font-weight:850}.fleet-selector{position:fixed;inset:0;z-index:30;display:grid;place-items:center;padding:18px;background:rgba(20,22,27,.48);backdrop-filter:blur(5px)}.fleet-selector[hidden]{display:none}.fleet-selector-card{position:relative;width:min(420px,100%);padding:24px;border-radius:22px;background:#fff;box-shadow:0 24px 80px rgba(30,34,43,.22)}.fleet-selector-card h2{margin:0;font-size:22px}.fleet-selector-card p{margin:8px 0 18px;color:#858b95;font-size:12px}.fleet-options{display:grid;gap:10px}.fleet-options button{display:grid;gap:5px;padding:14px;border:1px solid #e2e4e8;border-radius:13px;background:#fff;text-align:left}.fleet-options button.active{border-color:#ffc400;background:#fff8df}.fleet-options strong{font-size:12px}.fleet-options small{color:#8b919a}
@media(max-width:767px){.passenger-topbar{padding:14px}.city-warning{width:calc(100% - 24px)}.passenger-cabinet{inset:0;width:auto;padding:18px;border:0;border-radius:0;overflow:auto}.profile-nav{position:sticky;top:0;z-index:2;margin:-18px -18px 22px;padding:14px 18px;border-bottom:1px solid #eceef1;background:rgba(255,255,255,.96);backdrop-filter:blur(10px)}.ride-sheet{height:116px;overflow:hidden;cursor:pointer;padding-bottom:14px;touch-action:pan-y}.ride-sheet .ride-form,.ride-sheet .guest-help{opacity:0;pointer-events:none;transform:translateY(8px);transition:.18s ease}.ride-sheet h1{margin-bottom:0}.ride-sheet.expanded{top:86px;height:auto;max-height:calc(100vh - 104px);overflow:auto;cursor:default}.ride-sheet.expanded .ride-form,.ride-sheet.expanded .guest-help{opacity:1;pointer-events:auto;transform:none}.ride-sheet.expanded h1{margin-bottom:16px}}
.map-layer:before,.map-layer:after{display:none}.yandex-map{position:absolute;inset:0;width:100%;height:100%;background:#e8edf1}
.map-layer[data-map-status="unavailable"]:after{content:"Карта временно недоступна";position:absolute;left:50%;top:50%;z-index:1;display:grid;width:auto;height:auto;padding:12px 16px;border:1px solid #e7d8a0;border-radius:14px;background:rgba(255,248,223,.94);color:#17191f;font-size:12px;font-weight:850;box-shadow:0 14px 36px rgba(30,34,43,.12);transform:translate(-50%,-50%)}
.map-choice-card{position:fixed;left:50%;bottom:24px;z-index:9;width:min(520px,calc(100% - 28px));display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px 14px 14px 16px;border:1px solid #e4e5e8;border-radius:20px;background:rgba(255,255,255,.97);box-shadow:0 18px 60px rgba(30,34,43,.2);transform:translateX(-50%)}.map-choice-card[hidden]{display:none}.map-choice-card small,.map-choice-card strong{display:block}.map-choice-card small{color:#8b919a;font-size:9px;font-weight:850}.map-choice-card strong{margin-top:5px;font-size:12px;line-height:1.35}.map-choice-card button{height:44px;padding:0 16px;border:0;border-radius:13px;background:#ffc400;color:#17191f;font-size:11px;font-weight:900;white-space:nowrap}.map-selected-marker{position:relative;width:26px;height:26px;border:4px solid #fff;border-radius:50% 50% 50% 0;background:#ffc400;box-shadow:0 8px 22px rgba(30,34,43,.28);transform:translate(-50%,-100%) rotate(-45deg)}.map-selected-marker:after{content:"";position:absolute;left:50%;top:50%;width:7px;height:7px;border-radius:50%;background:#17191f;transform:translate(-50%,-50%)}@media(min-width:900px){.map-choice-card{left:auto;right:38px;bottom:38px;transform:none}}@media(max-width:767px){.map-choice-card{bottom:18px;grid-template-columns:1fr}.map-choice-card button{width:100%}}
.map-user-location-marker{position:relative;width:48px;height:48px;border-radius:50%;background:rgba(35,132,255,.18);transform:translate(-50%,-50%);animation:user-location-pulse 1.8s ease-in-out infinite}.map-user-location-marker span{position:absolute;left:50%;top:50%;width:18px;height:18px;border:4px solid #fff;border-radius:50%;background:#2384ff;box-shadow:0 8px 20px rgba(35,132,255,.45);transform:translate(-50%,-50%)}@keyframes user-location-pulse{0%,100%{box-shadow:0 0 0 0 rgba(35,132,255,.22)}50%{box-shadow:0 0 0 10px rgba(35,132,255,0)}}
.location-button{display:grid;place-items:center}.location-button svg{width:18px;height:18px;fill:#17191f;transform:rotate(45deg)}
.passenger-topbar{display:grid;grid-template-columns:42px minmax(0,1fr) 42px;align-items:center}.cabinet-button{width:42px;padding:0;display:grid;place-items:center}.cabinet-button svg{width:19px;height:19px;fill:#17191f}.city-button{justify-self:center;max-width:min(260px,calc(100vw - 136px));height:42px;display:flex;align-items:center;gap:6px;padding:0 14px;border:0;border-radius:14px;background:#fff;color:#17191f;font-size:12px;font-weight:900;box-shadow:0 10px 30px rgba(30,34,43,.12)}.city-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.city-button svg{width:16px;height:16px;fill:#818793;flex:0 0 auto}.city-selector{position:fixed;inset:0;z-index:35;display:flex;align-items:flex-end;justify-content:center;background:rgba(20,22,27,.42);backdrop-filter:blur(5px)}.city-selector[hidden]{display:none}.city-selector-card{position:relative;width:min(560px,100%);max-height:min(82vh,720px);display:flex;flex-direction:column;padding:12px 18px 18px;border-radius:28px 28px 0 0;background:#fff;box-shadow:0 -22px 70px rgba(30,34,43,.22);animation:city-sheet-up .22s ease-out}.city-selector-handle{width:42px;height:4px;margin:0 auto 18px;border-radius:99px;background:#d8dbe0}.city-selector-close{position:absolute;top:17px;right:16px;width:34px;height:34px;border:0;border-radius:12px;background:#f1f2f4;color:#17191f;font-size:20px;line-height:1}.city-selector-card h2{margin:0 42px 7px 0;font-size:24px}.city-selector-card p{margin:0 0 16px;color:#727985;font-size:12px;line-height:1.45}.city-search{display:grid;gap:7px;margin-bottom:12px;color:#737984;font-size:10px;font-weight:850}.city-search input{height:46px;padding:0 14px;border:1px solid #dfe2e6;border-radius:14px;background:#fff;font:inherit;font-size:13px}.city-options{display:grid;gap:9px;overflow:auto;padding:2px 0 10px}.city-options button{display:grid;gap:5px;padding:13px 14px;border:1px solid #e2e4e8;border-radius:14px;background:#fff;text-align:left}.city-options button.active{border-color:#ffc400;background:#fff8df}.city-options strong{font-size:13px}.city-options small,.city-empty{color:#8b919a;font-size:11px}.city-empty{padding:16px;border-radius:14px;background:#f6f7f8}.city-application-link{display:block;margin-top:8px;padding:13px 14px;border-radius:14px;background:#17191f;color:#ffc400;font-size:12px;font-weight:900;text-align:center;text-decoration:none}@keyframes city-sheet-up{from{transform:translateY(24px);opacity:.75}to{transform:none;opacity:1}}@media(min-width:768px){.city-selector{align-items:center}.city-selector-card{border-radius:26px;max-height:min(760px,88vh)}}@media(max-width:767px){.city-button{max-width:calc(100vw - 126px)}}
input,textarea,select{font-size:16px}.city-search input,.ride-form input{font-size:16px}@media(max-width:767px){.city-selector{align-items:stretch;background:#fff;backdrop-filter:none}.city-selector-card{width:100%;height:100%;max-height:none;padding:calc(10px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));border-radius:0;box-shadow:none;animation:city-sheet-full-up .24s ease-out}.city-selector-handle{margin-bottom:20px}.city-selector-close{top:calc(15px + env(safe-area-inset-top));right:16px}.city-selector-card h2{font-size:26px}.city-selector-card p{font-size:13px}.city-options{flex:1;min-height:0}.city-application-link{margin-top:10px}}@keyframes city-sheet-full-up{from{transform:translateY(100%)}to{transform:none}}
@media(max-width:767px){.passenger-topbar{padding:calc(12px + env(safe-area-inset-top)) 14px 14px}.city-warning{margin-top:calc(4px + env(safe-area-inset-top))}.city-selector-card{display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr) auto;overflow:hidden}.city-selector-handle,.city-selector-card h2,.city-selector-card p,.city-search,.city-selector-close{flex:0 0 auto}.city-search{position:sticky;top:0;z-index:2;background:#fff}.city-options{overflow:auto;-webkit-overflow-scrolling:touch;padding-bottom:12px}.city-application-link{flex:0 0 auto}}
html,body{width:100%;height:100%;min-height:100%;overflow:hidden;overscroll-behavior:none;background:#e8edf1}body{position:fixed;inset:0;touch-action:none}.passenger-app{height:var(--app-height,100dvh);min-height:var(--app-height,100dvh);max-height:var(--app-height,100dvh);overflow:hidden;overscroll-behavior:none;touch-action:none;background:#e8edf1}.map-layer{position:fixed;inset:0;width:100vw;height:var(--app-height,100dvh);min-height:100svh;overscroll-behavior:none}.yandex-map{height:100%}.ride-sheet,.passenger-topbar,.city-warning,.passenger-cabinet,.fleet-selector,.city-selector,.map-choice-card{touch-action:auto}@supports(height:100dvh){.passenger-app,.map-layer{height:100dvh;min-height:100dvh;max-height:100dvh}}@media(max-width:767px){.ride-sheet.expanded{max-height:calc(var(--app-height,100dvh) - 104px)}}
