*{margin:0;padding:0;box-sizing:border-box}
:root{
  --yellow:#FFB800;
  --yellow-dark:#e0a200;
  --bg:#0f0f0f;
  --bg2:#181818;
  --bg3:#1f1f1f;
  --white:#fff;
  --gray:#888;
  --light:#ccc;
}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--white);line-height:1.5;font-size:15px}
a{color:inherit;text-decoration:none}
img{max-width:100%}

/* TOP BAR */
.topbar{background:#111;border-bottom:1px solid #222;padding:6px 0;font-size:13px}
.topbar .inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.topbar-phone{color:var(--yellow);font-weight:700;font-size:16px;letter-spacing:.5px}
.topbar-phone span{color:#aaa;font-size:12px;font-weight:400;margin-left:6px}
.topbar-socials{display:flex;gap:8px;align-items:center}
.soc-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer;transition:.2s}
.soc-tg{background:transparent}
.soc-wa{background:transparent}
.soc-vk{background:transparent}

/* HEADER */
header{background:#0f0f0f;border-bottom:1px solid #222;position:sticky;top:0;z-index:100}
.header-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:32px;height:64px}
.logo{display:flex;align-items:center;gap:0;flex-shrink:0}
.logo img{height:38px;width:auto}
nav{display:flex;gap:4px;align-items:center;flex:1}
nav a{color:#ccc;font-size:14px;font-weight:500;padding:8px 12px;border-radius:6px;transition:.2s;white-space:nowrap}
nav a:hover{color:var(--yellow);background:#1a1a1a}
.header-cta{margin-left:auto;display:flex;align-items:center;gap:12px;flex-shrink:0}
.btn-yellow{background:var(--yellow);color:#000;font-weight:700;font-size:14px;padding:10px 20px;border-radius:8px;cursor:pointer;border:none;transition:.2s;white-space:nowrap}
.btn-yellow:hover{background:var(--yellow-dark)}

/* HERO */
.hero{background:#0f0f0f;background-size:cover;background-position:center 40%;position:relative;overflow:hidden;min-height:520px;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;background:linear-gradient(100deg,rgba(10,10,10,0.92) 0%,rgba(10,10,10,0.80) 42%,rgba(10,10,10,0.45) 65%,rgba(10,10,10,0.15) 100%);z-index:1}
.hero-car{display:none}
.hero-car-img{display:none}
.hero-inner{max-width:1280px;margin:0 auto;padding:60px 24px;display:flex;gap:40px;align-items:center;position:relative;z-index:2;width:100%}
.hero-content{flex:1;max-width:540px}
.hero-tag{background:var(--yellow);color:#000;font-size:12px;font-weight:700;padding:4px 12px;border-radius:4px;display:inline-block;margin-bottom:18px;letter-spacing:.5px;text-transform:uppercase}
.hero-title{font-size:42px;font-weight:900;line-height:1.1;margin-bottom:16px;text-transform:uppercase}
.hero-title span{color:var(--yellow)}
.hero-sub{color:#bbb;font-size:16px;margin-bottom:28px;line-height:1.6}
.hero-badges{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:0}
.badge{display:flex;align-items:center;gap:8px;color:#ccc;font-size:13px}
.badge-icon{width:36px;height:36px;background:var(--yellow);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.badge-icon svg{width:18px;height:18px;fill:#000}

/* BOOKING FORM */
.booking-form{background:#181818;border:1px solid #2a2a2a;border-radius:16px;padding:28px;min-width:340px;max-width:380px;flex-shrink:0}
.booking-form h3{font-size:16px;font-weight:700;margin-bottom:4px}
.booking-form .form-sub{color:#888;font-size:13px;margin-bottom:20px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;color:#888;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.form-group input,.form-group select{width:100%;background:#111;border:1px solid #2a2a2a;border-radius:8px;padding:12px 14px;color:#fff;font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:.2s}
.form-group input::placeholder{color:#555}
.form-group input:focus,.form-group select:focus{border-color:var(--yellow)}
.form-group select{color:#555;cursor:pointer}
.form-group select option{background:#222}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-submit{width:100%;background:var(--yellow);color:#000;font-weight:800;font-size:16px;padding:14px;border-radius:10px;border:none;cursor:pointer;transition:.2s;margin-top:6px;font-family:'Inter',sans-serif}
.form-submit:hover{background:var(--yellow-dark)}
.form-socials{margin-top:14px;text-align:center;color:#666;font-size:12px}
.form-socials-row{display:flex;justify-content:center;gap:8px;margin-top:8px}

/* SECTION */
.section{padding:60px 0}
.section-dark{background:var(--bg2)}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.section-title{font-size:28px;font-weight:800;text-align:center;margin-bottom:8px;text-transform:uppercase}
.section-title span{color:var(--yellow)}
.section-sub{text-align:center;color:#888;font-size:14px;margin-bottom:36px}

/* PRICES TABLE */
.prices-table{width:100%;border-collapse:collapse;font-size:14px}
.prices-table th{background:#1a1a1a;color:#aaa;font-weight:600;font-size:12px;text-transform:uppercase;padding:12px 16px;text-align:left;border-bottom:1px solid #2a2a2a}
.prices-table td{padding:12px 16px;border-bottom:1px solid #1e1e1e;vertical-align:middle}
.prices-table tr:hover td{background:#1a1a1a}
.prices-table tr:first-child th:first-child{border-radius:8px 0 0 0}
.prices-table tr:first-child th:last-child{border-radius:0 8px 0 0}
.route-name{font-weight:600;color:#fff}
.route-from{color:#888;font-size:12px;margin-top:2px}
.price-cell{font-weight:700;color:var(--yellow)}
.price-note{font-size:11px;color:#666;margin-top:2px}
.btn-order{background:var(--yellow);color:#000;font-weight:700;font-size:13px;padding:8px 16px;border-radius:6px;border:none;cursor:pointer;font-family:'Inter',sans-serif;white-space:nowrap;transition:.2s}
.btn-order:hover{background:var(--yellow-dark)}
.table-note{color:#666;font-size:12px;margin-top:12px;text-align:center}

/* TARIFFS */
.tariffs-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.tariff-card{background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:20px;transition:.2s;cursor:pointer}
.tariff-card:hover{border-color:var(--yellow);transform:translateY(-2px)}
.tariff-card.featured{border-color:var(--yellow);background:#1a1700}
.tariff-car{height:80px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;overflow: hidden;}
.tariff-car-placeholder{width:100%;height:70px;background:#222;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#444;font-size:11px;text-align:center}
.tariff-name{font-size:16px;font-weight:800;text-transform:uppercase;margin-bottom:4px}
.tariff-price{color:var(--yellow);font-size:13px;font-weight:700;margin-bottom:14px}
.tariff-features{list-style:none;margin-bottom:18px}
.tariff-features li{font-size:13px;color:#bbb;padding:3px 0;display:flex;align-items:center;gap:6px}
.tariff-features li::before{content:'✓';color:var(--yellow);font-weight:700;font-size:12px}
.tariff-btn{width:100%;background:var(--yellow);color:#000;font-weight:700;font-size:14px;padding:11px;border-radius:8px;border:none;cursor:pointer;font-family:'Inter',sans-serif;transition:.2s}
.tariff-btn:hover{background:var(--yellow-dark)}

/* PROMO */
.promo-section{background:var(--bg);padding:48px 0}
.promo-inner{display:grid;/* grid-template-columns:1fr 1fr; */gap:32px;align-items:stretch}
.promo-card{background:#181818;border:1px solid #2a2a2a;border-radius:16px;position:relative;overflow:hidden}
.promo-badge{background:var(--yellow);color:#000;font-size:12px;font-weight:800;padding:4px 10px;border-radius:4px;display:inline-block;margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}
.promo-title{font-size:24px;font-weight:800;margin-bottom:10px}
.promo-text{color:#bbb;font-size:14px;margin-bottom:22px;line-height:1.6}
.promo-gift{position:absolute;right:0;top:50%;transform:translateY(-50%);width:260px;height:260px;overflow:hidden;pointer-events:none}.promo-gift__img{width:100%;height:100%;object-fit:cover;opacity:.45;border-radius:0 12px 12px 0;display:block;}
.contacts-card{background:#181818;border:1px solid #2a2a2a;border-radius:16px;padding:36px}
.contacts-title{font-size:22px;font-weight:800;margin-bottom:20px}
.contacts-grid{display: flex;grid-template-columns:1fr 1fr;gap:14px 20px;justify-content: space-between;}
.contact-item{display:flex;align-items:center;gap:12px;font-size:15px;font-weight:600;margin-bottom:0;color:inherit;text-decoration:none;transition:.2s;border-radius:8px;padding:4px}
.contact-item:hover{color:var(--yellow)}
.contact-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.ci-phone{background:transparent}
.ci-tg{background:transparent}
.ci-wa{background:transparent}
.ci-vk{background:transparent}
.ci-max{background:transparent}

/* TRANSFERS */
.transfers-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.transfer-card{background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:20px;text-align:center;transition:.2s}
.transfer-card:hover{border-color:var(--yellow)}
.transfer-icon{font-size:32px;margin-bottom:10px}
.transfer-name{font-size:14px;font-weight:700;margin-bottom:4px}
.transfer-price{color:var(--yellow);font-weight:800;font-size:16px;margin-bottom:14px}
.transfer-price small{font-size:12px;color:#888;font-weight:400}

/* POPULAR DIRECTIONS */
.directions-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.direction-card{border-radius:12px;overflow:hidden;position:relative;height:160px;cursor:pointer;background:#222;transition:.2s;display:block}
.direction-card:hover{transform:translateY(-3px)}
.direction-img{width:100%;height:100%;object-fit:cover;opacity:.6;transition:.3s}
.direction-card:hover .direction-img{opacity:.8}
.direction-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0;transition:transform .4s ease;display:block}
.direction-card:hover .direction-bg-img{transform:scale(1.05)}
.direction-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.92) 100%);z-index:1}
.direction-name{position:absolute;bottom:30px;left:16px;right:16px;font-size:14px;font-weight:700;z-index:2;color:#fff}
.direction-price{position:absolute;bottom:10px;left:16px;color:var(--yellow);font-size:13px;font-weight:700;z-index:2}
.direction-btn{position:absolute;bottom:14px;right:16px;z-index:2}
.direction-photo{width:100%;height:100%;object-fit:cover}
.photo-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a1a 0%,#2a2a2a 100%);display:flex;align-items:center;justify-content:center;color:#444;font-size:11px;text-align:center;padding:8px}

/* HOW TO ORDER */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.step{text-align:center;padding:32px 24px;background:#181818;border-radius:16px;border:1px solid #222;position:relative}
.step-num{width:56px;height:56px;border-radius:50%;background:var(--yellow);color:#000;font-size:24px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.step-title{font-size:18px;font-weight:700;margin-bottom:10px}
.step-text{color:#888;font-size:14px;line-height:1.6}
.step-arrow{position:absolute;right:-28px;top:50%;transform:translateY(-50%);color:#333;font-size:28px;z-index:1}

/* ABOUT + FAQ */
.about-faq{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.about-text{font-size:15px;color:#bbb;line-height:1.8;margin-bottom:20px}
.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.article-card{background:#181818;border:1px solid #222;border-radius:12px;overflow:hidden;cursor:pointer;transition:.2s}
.article-card:hover{border-color:var(--yellow)}
.article-img{height:110px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e1e1e,#2e2e2e)}
.article-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .3s}
.article-card:hover .article-img img{transform:scale(1.05)}
.article-body{padding:14px}
.article-title{font-size:14px;font-weight:700;margin-bottom:6px;line-height:1.4}
.article-link{color:var(--yellow);font-size:13px;font-weight:600}
.faq-list{list-style:none}
.faq-item{border-bottom:1px solid #222;overflow:hidden}
.faq-question{width:100%;background:none;border:none;color:#fff;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;padding:18px 0;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-question:hover{color:var(--yellow)}
.faq-icon{color:var(--yellow);font-size:20px;flex-shrink:0;transition:.3s}
.faq-answer{font-size:14px;color:#aaa;line-height:1.7;padding:0 0 16px;display:none}
.faq-item.open .faq-answer{display:block}
.faq-item.open .faq-icon{transform:rotate(45deg)}

/* CTA BOTTOM */
.cta-bottom{background:linear-gradient(135deg,#181800 0%,#181818 100%);border-top:2px solid var(--yellow);padding:60px 0;text-align:center}
.cta-bottom h2{font-size:32px;font-weight:900;text-transform:uppercase;margin-bottom:8px}
.cta-bottom h2 span{color:var(--yellow)}
.cta-bottom p{color:#888;margin-bottom:32px;font-size:15px}
.cta-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;max-width:640px;margin:0 auto 24px}
.cta-input{flex:1;min-width:200px;background:#111;border:1px solid #333;border-radius:10px;padding:14px 18px;color:#fff;font-size:15px;font-family:'Inter',sans-serif;outline:none}
.cta-input:focus{border-color:var(--yellow)}
.cta-input::placeholder{color:#555}
.cta-socials{color:#666;font-size:13px}
.cta-soc-row{display:flex;gap:10px;justify-content:center;margin-top:10px}

/* FOOTER */
footer{background:#0a0a0a;border-top:1px solid #1e1e1e;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo{/* margin-bottom:14px; */}
.footer-logo img{height:32px}
.footer-desc{color:#666;font-size:13px;line-height:1.7;margin-bottom:16px}
.footer-socials{display:flex;gap:8px}
.footer-col h4{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;color:#fff}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:#666;font-size:13px;transition:.2s}
.footer-col ul li a:hover{color:var(--yellow)}
.footer-bottom{border-top:1px solid #1e1e1e;padding-top:24px;display:flex;justify-content:space-between;align-items:center;color:#555;font-size:13px}
.footer-bottom a{color:#666}
.footer-bottom a:hover{color:var(--yellow)}

/* UTILS */
.text-yellow{color:var(--yellow)}
.btn-outline{background:transparent;border:2px solid var(--yellow);color:var(--yellow);font-weight:700;font-size:14px;padding:10px 22px;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;transition:.2s}
.btn-outline:hover{background:var(--yellow);color:#000}
.all-btn-row{text-align:center;margin-top:28px}

@media(max-width:1024px){
  .tariffs-grid,.transfers-grid,.directions-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .hero-inner{flex-direction:column}
  .booking-form{min-width:auto;width:100%}
  .hero-title{font-size:28px}
  .tariffs-grid,.transfers-grid,.directions-grid{grid-template-columns:1fr 1fr}
  .about-faq,.promo-inner{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step-arrow{display:none}
  .prices-table{font-size:13px}
  header nav{display:none}
}


/* directions */

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --yellow:#FFB800;
  --yellow-dark:#e0a200;
  --bg:#0f0f0f;
  --bg2:#181818;
  --bg3:#1f1f1f;
  --white:#fff;
  --gray:#888;
}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--white);line-height:1.5;font-size:15px}
a{color:inherit;text-decoration:none}
img{max-width:100%}

.topbar{background:#111;border-bottom:1px solid #222;padding:6px 0;font-size:13px}
.topbar .inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.topbar-phone{color:var(--yellow);font-weight:700;font-size:16px}
.topbar-phone span{color:#aaa;font-size:12px;font-weight:400;margin-left:6px}
.topbar-socials{display:flex;gap:8px}
.soc-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s}
.soc-tg{background:transparent}
.soc-wa{background:transparent}
.soc-vk{background:transparent}

header{background:#0f0f0f;border-bottom:1px solid #222;position:sticky;top:0;z-index:100}
.header-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:32px;height:64px}
.logo img{height:38px}
nav{display:flex;gap:4px;align-items:center;flex:1}
nav a{color:#ccc;font-size:14px;font-weight:500;padding:8px 12px;border-radius:6px;transition:.2s;white-space:nowrap}
nav a:hover,nav a.active{color:var(--yellow);background:#1a1a1a}
.btn-yellow{background:var(--yellow);color:#000;font-weight:700;font-size:14px;padding:10px 20px;border-radius:8px;cursor:pointer;border:none;transition:.2s}
.btn-yellow:hover{background:var(--yellow-dark)}

/* BREADCRUMB */
.breadcrumb{background:#111;border-bottom:1px solid #1e1e1e;padding:10px 0}
.breadcrumb .inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;gap:8px;align-items:center;font-size:13px;color:#666}
.breadcrumb a{color:#666;transition:.2s}
.breadcrumb a:hover{color:var(--yellow)}
.breadcrumb span{color:#444}

/* DIRECTION HERO */
.dir-hero{background:#0f0f0f;padding:56px 0 48px;position:relative;overflow:hidden;border-bottom:1px solid #1e1e1e}
.dir-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(255,184,0,.06) 0%,transparent 70%)}
.dir-hero-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
.dir-hero-tag{display:inline-flex;align-items:center;gap:8px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:6px;padding:6px 14px;font-size:13px;color:#aaa;margin-bottom:20px}
.dir-hero-tag span{color:var(--yellow);font-weight:700}
.dir-route{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.dir-city{font-size:40px;font-weight:900;text-transform:uppercase;line-height:1}
.dir-arrow{font-size:32px;color:var(--yellow)}
.dir-sub{color:#bbb;font-size:16px;margin-bottom:32px;line-height:1.7;max-width:560px}
.dir-stats{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:36px}
.dir-stat{background:#181818;border:1px solid #2a2a2a;border-radius:10px;padding:14px 20px;min-width:120px}
.dir-stat-val{font-size:22px;font-weight:800;color:var(--yellow);line-height:1}
.dir-stat-label{font-size:12px;color:#666;margin-top:4px}
.dir-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-outline{background:transparent;border:2px solid var(--yellow);color:var(--yellow);font-weight:700;font-size:14px;padding:12px 24px;border-radius:8px;cursor:pointer;font-family:'Inter',sans-serif;transition:.2s}
.btn-outline:hover{background:var(--yellow);color:#000}

/* BOOKING FORM */
.booking-form{background:#181818;border:1px solid #2a2a2a;border-radius:16px;padding:28px}
.booking-form h3{font-size:17px;font-weight:700;margin-bottom:4px}
.form-sub{color:#888;font-size:13px;margin-bottom:20px}
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;color:#888;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.form-group input,.form-group select{width:100%;background:#111;border:1px solid #2a2a2a;border-radius:8px;padding:12px 14px;color:#fff;font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:.2s}
.form-group input::placeholder{color:#555}
.form-group input:focus{border-color:var(--yellow)}
.form-group select{color:#555}
.form-group select option{background:#222}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-submit{width:100%;background:var(--yellow);color:#000;font-weight:800;font-size:16px;padding:14px;border-radius:10px;border:none;cursor:pointer;transition:.2s;margin-top:6px;font-family:'Inter',sans-serif}
.form-submit:hover{background:var(--yellow-dark)}
.form-note{text-align:center;color:#555;font-size:12px;margin-top:10px}

/* SECTIONS */
.section{padding:56px 0}
.section-dark{background:var(--bg2)}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
.section-title{font-size:26px;font-weight:800;margin-bottom:8px;text-transform:uppercase}
.section-title span{color:var(--yellow)}
.section-sub{color:#888;font-size:14px;margin-bottom:32px}

/* ROUTE DETAILS */
.route-details{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}
.route-map-placeholder{background:#181818;border:1px solid #2a2a2a;border-radius:16px;height:340px;display:flex;align-items:center;justify-content:center;color:#444;font-size:14px;flex-direction:column;gap:8px}
.route-stops{background:#181818;border:1px solid #2a2a2a;border-radius:16px;padding:24px}
.route-stops h4{font-size:16px;font-weight:700;margin-bottom:20px;color:#fff}
.stop-item{display:flex;gap:14px;align-items:flex-start;padding-bottom:20px;position:relative}
.stop-item:not(:last-child)::after{content:'';position:absolute;left:11px;top:24px;bottom:0;width:2px;background:#2a2a2a}
.stop-dot{width:22px;height:22px;border-radius:50%;background:var(--yellow);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#000;margin-top:2px}
.stop-dot.end{background:#333;border:2px solid var(--yellow)}
.stop-name{font-weight:700;font-size:15px}
.stop-desc{font-size:13px;color:#666;margin-top:2px}
.stop-time{font-size:13px;color:var(--yellow);font-weight:600;margin-top:4px}

/* TARIFF PRICES */
.tariff-prices{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.tp-card{background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:20px;text-align:center;transition:.2s;cursor:pointer}
.tp-card:hover,.tp-card.active{border-color:var(--yellow);background:#1a1700}
.tp-icon{font-size:28px;margin-bottom:10px}
.tp-name{font-size:14px;font-weight:700;text-transform:uppercase;margin-bottom:4px}
.tp-seats{font-size:12px;color:#666;margin-bottom:12px}
.tp-price{font-size:22px;font-weight:900;color:var(--yellow);margin-bottom:4px}
.tp-note{font-size:11px;color:#555;margin-bottom:16px}
.tp-btn{width:100%;background:var(--yellow);color:#000;font-weight:700;font-size:13px;padding:10px;border-radius:8px;border:none;cursor:pointer;font-family:'Inter',sans-serif;transition:.2s}
.tp-btn:hover{background:var(--yellow-dark)}

/* INFO CARDS */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.info-card{background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:24px}
.info-card-icon{font-size:32px;margin-bottom:12px}
.info-card-title{font-size:16px;font-weight:700;margin-bottom:8px}
.info-card-text{font-size:14px;color:#888;line-height:1.7}

/* OTHER DIRECTIONS */
.other-dirs{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.other-card{background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:20px;display:flex;justify-content:space-between;align-items:center;transition:.2s;cursor:pointer}
.other-card:hover{border-color:var(--yellow)}
.other-from{font-size:12px;color:#666;margin-bottom:4px}
.other-route{font-size:15px;font-weight:700}
.other-price{color:var(--yellow);font-weight:800;font-size:16px;text-align:right}
.other-price-label{font-size:11px;color:#666;font-weight:400}

/* FAQ */
.faq-list{list-style:none}
.faq-item{border-bottom:1px solid #222;overflow:hidden}
.faq-question{width:100%;background:none;border:none;color:#fff;font-family:'Inter',sans-serif;font-size:15px;font-weight:600;padding:18px 0;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq-question:hover{color:var(--yellow)}
.faq-icon{color:var(--yellow);font-size:20px;flex-shrink:0;transition:.3s}
.faq-answer{font-size:14px;color:#aaa;line-height:1.7;padding:0 0 16px;display:none}
.faq-item.open .faq-answer{display:block}
.faq-item.open .faq-icon{transform:rotate(45deg)}

/* CTA */
.cta-bottom{background:linear-gradient(135deg,#181800,#181818);border-top:2px solid var(--yellow);padding:56px 0;text-align:center}
.cta-bottom h2{font-size:30px;font-weight:900;text-transform:uppercase;margin-bottom:8px}
.cta-bottom h2 span{color:var(--yellow)}
.cta-bottom p{color:#888;margin-bottom:32px}
.cta-form{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;max-width:640px;margin:0 auto 24px}
.cta-input{flex:1;min-width:180px;background:#111;border:1px solid #333;border-radius:10px;padding:14px 18px;color:#fff;font-size:15px;font-family:'Inter',sans-serif;outline:none}
.cta-input:focus{border-color:var(--yellow)}
.cta-input::placeholder{color:#555}

/* FOOTER */
footer{background:#0a0a0a;border-top:1px solid #1e1e1e;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-logo img{height: 50px;/* margin-bottom:14px; */}
.footer-desc{color:#666;font-size:13px;line-height:1.7;margin-bottom:16px}
.footer-socials{display:flex;gap:8px}
.footer-col h4{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{color:#666;font-size:13px;transition:.2s}
.footer-col ul li a:hover{color:var(--yellow)}
.footer-bottom{border-top:1px solid #1e1e1e;padding-top:24px;display:flex;justify-content:space-between;align-items:center;color:#555;font-size:13px}
.footer-bottom a{color:#666}
.footer-bottom a:hover{color:var(--yellow)}

/* REVIEWS */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{background:#181818;border:1px solid #2a2a2a;border-radius:12px;padding:22px}
.review-stars{color:var(--yellow);font-size:16px;margin-bottom:10px}
.review-text{font-size:14px;color:#bbb;line-height:1.7;margin-bottom:14px}
.review-author{display:flex;align-items:center;gap:10px}
.review-avatar{width:36px;height:36px;border-radius:50%;background:#2a2a2a;display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--yellow);font-size:15px}
.review-name{font-weight:600;font-size:14px}
.review-date{font-size:12px;color:#555}

@media(max-width:1024px){
  .dir-hero-inner{grid-template-columns:1fr}
  .route-details{grid-template-columns:1fr}
  .tariff-prices{grid-template-columns:repeat(3,1fr)}
  .other-dirs{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .dir-route{flex-direction:column;align-items:flex-start;gap:8px}
  .dir-city{font-size:28px}
  .tariff-prices{grid-template-columns:1fr 1fr}
  .info-grid,.reviews-grid{grid-template-columns:1fr}
  nav{display:none}
}


/* WordPress helpers */
.admin-bar header{top:32px}
@media (max-width:782px){.admin-bar header{top:46px}}
.tweaks-panel{display:none !important}
.screen-reader-text{position:absolute;left:-9999px}

.tariff-car-image{width:100%;max-width:320px;height:auto;display:block;margin:0 auto;object-fit:contain;}

/* ===================================================
   FIX: Remove zebra — all sections same background
   =================================================== */
.section-dark { background: var(--bg) !important; }
.promo-section { background: var(--bg) !important; }

/* soc-btn: reset text, just show image */
.soc-btn { background: transparent !important; color: transparent !important; font-size: 0 !important; padding: 0; width: auto; height: auto; border-radius: 0; }
.soc-btn img { display: block; border-radius: 50%; transition: transform .2s, opacity .2s; }
.soc-btn img:hover { transform: scale(1.1); opacity: .85; }

/* ===================================================
   FIX: Remove zebra — all sections same background
   =================================================== */
.section-dark { background: var(--bg) !important; }
.promo-section { background: var(--bg) !important; }

/* Social icon buttons: image-only, no text bg */
.soc-btn {
    background: transparent !important;
    color: transparent !important;
    font-size: 0 !important;
    padding: 0;
    width: auto;
    height: auto;
    border-radius: 0;
    line-height: 0;
}
.soc-btn img {
    display: block;
    border-radius: 50%;
    transition: transform .2s, opacity .2s;
    width: 30px;
    height: 30px;
}
.soc-btn img:hover { transform: scale(1.1); opacity: .85; }

/* ===================================================
   HOW-TO STEPS BLOCK  — "Как заказать поездку"
   =================================================== */

.zts-how { padding-bottom: 0 !important; }

/* 4-column cards grid */
.zts-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    border: 1px solid #2e2e2e;
    border-radius: 16px 16px 0 0;
    overflow: visible;
}

/* Single card — no internal borders, text left-aligned like mockup */
.zts-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 52px 28px 32px 28px;
    background: var(--bg);
    /* NO border-right — removed per mockup */
}
.zts-card:first-child { border-radius: 16px 0 0 0; }
.zts-card:last-child  { border-radius: 0 16px 0 0; }

/* Arrow — centered between cards, larger */
.zts-card__arrow {
    position: absolute;
    right: -22px;
    top: 50%;
    transform: translateY(-160%);
    z-index: 5;
    width: 44px;
    height: 44px;
    background: var(--bg);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.zts-card__arrow img { width: 32px; height: 32px; object-fit: contain; }

/* Step number — top-left corner of card */
.zts-card__num {
    position: absolute;
    top: 30px;
    left: 20px;
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}
.zts-card__num img {
    width: 52px;
    height: 52px;
    object-fit: contain;
}

/* Icon */
.zts-card__icon {
    width: 110px;
    height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}
.zts-card__icon img {
    width: 96px;
    height: 96px;
    object-fit: contain;
}

/* Title */
.zts-card__title {
    font-size: 16px;
    font-weight: 800;
    color: var(--white);
    line-height: 1.3;
    margin-bottom: 14px;
    min-height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Yellow divider line */
.zts-card__line {
    width: 36px;
    height: 3px;
    background: var(--yellow);
    border-radius: 2px;
    margin: 0 auto 16px;
    flex-shrink: 0;
}

/* Description */
.zts-card__text {
    font-size: 13px;
    color: #888;
    line-height: 1.7;
    flex: 1;
    margin-bottom: 24px;
}

/* ── Card 1: Social buttons (outline pill style matching mockup) ── */
.zts-socials {
    display: flex;
    flex-direction: row;
    gap: 8px;
    width: 100%;
    margin-top: auto;
    justify-content: center;
}
.zts-soc-pill {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    padding: 12px 10px 10px;
    border-radius: 10px;
    border: 1.5px solid #3a3a3a;
    background: transparent;
    color: var(--white);
    font-size: 11.5px;
    font-weight: 600;
    text-decoration: none;
    transition: border-color .2s, background .2s, transform .15s;
    cursor: pointer;
    flex: 1;
    min-width: 0;
}
.zts-soc-pill:hover {
    border-color: var(--yellow);
    background: rgba(255,184,0,.06);
    transform: translateY(-2px);
}
.zts-soc-pill__icon {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.zts-soc-pill__icon svg {
    width: 36px;
    height: 36px;
}
.zts-soc-pill__label {
    color: var(--white);
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    text-align: center;
}

/* ── Cards 2–4: Badge pill ── */
.zts-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 11px 16px;
    border-radius: 10px;
    border: 1px solid #2d2d2d;
    background: #121212;
    color: var(--yellow);
    font-size: 13px;
    font-weight: 700;
    margin-top: auto;
    transition: border-color .2s, background .2s;
    cursor: default;
}
.zts-badge:hover {
    border-color: var(--yellow);
    background: rgba(255,184,0,.06);
}
.zts-badge svg { flex-shrink: 0; stroke: var(--yellow); }

/* ── Bottom features bar ── */
.zts-bar {
    display: flex;
    align-items: stretch;
    border: 1px solid #2e2e2e;
    border-top: none;
    border-radius: 0 0 16px 16px;
    overflow: hidden;
    background: var(--bg);
}
.zts-bar__item {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 20px 18px;
    border-right: none;
}
.zts-bar__item:last-child { border-right: none; }
.zts-bar__item svg {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    stroke: var(--yellow);
    color: var(--yellow);
}
.zts-bar__item img {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
    object-fit: contain;
}
.zts-bar__item div { display: flex; flex-direction: column; gap: 3px; }
.zts-bar__item strong { font-size: 13px; font-weight: 700; color: var(--white); line-height: 1.3; }
.zts-bar__item span   { font-size: 12px; color: #666; line-height: 1.3; }

/* ── Responsive ── */
@media (max-width: 1100px) {
    .zts-card__title { font-size: 14px; min-height: 36px; }
    .zts-card { padding: 52px 16px 24px 16px; }
    .zts-card__icon { width: 80px; height: 80px; }
    .zts-card__icon img { width: 72px; height: 72px; }
    .zts-bar__item strong { font-size: 11.5px; }
    .zts-card__num { left: 12px; }
}

@media (max-width: 860px) {
    .zts-grid {
        grid-template-columns: repeat(2, 1fr);
        border-radius: 12px 12px 0 0;
    }
    .zts-card { border-bottom: 1px solid #2a2a2a; }
    .zts-card:nth-child(3),
    .zts-card:nth-child(4) { border-bottom: none; }
    .zts-card:first-child  { border-radius: 12px 0 0 0; }
    .zts-card:nth-child(2) { border-radius: 0 12px 0 0; }
    .zts-card:nth-child(3) { border-radius: 0 0 0 12px; }
    .zts-card:last-child   { border-radius: 0 0 12px 0; }
    .zts-card__arrow { display: none; }
    .zts-bar { flex-wrap: wrap; border-radius: 0 0 12px 12px; }
    .zts-bar__item { flex: 0 0 50%; border-right: none; border-bottom: 1px solid #222; }
    .zts-bar__item:nth-child(odd)  { border-right: 1px solid #222; }
    .zts-bar__item:nth-last-child(-n+2) { border-bottom: none; }
}

@media (max-width: 480px) {
    .zts-grid { grid-template-columns: 1fr; border-radius: 12px 12px 0 0; }
    .zts-card { border-radius: 0 !important; border-bottom: 1px solid #2a2a2a; }
    .zts-card:first-child  { border-radius: 12px 12px 0 0 !important; }
    .zts-card:last-child   { border-bottom: none; }
    .zts-bar { flex-direction: column; }
    .zts-bar__item { flex: 1; width: 100%; border-right: none !important; border-bottom: 1px solid #222; }
    .zts-bar__item:last-child { border-bottom: none; }
}

.zt-badge__icon{border:none!important;background:none!important;}
.zt-badge__icon img{width:38px;height:38px;object-fit:contain;}

.zt-feature__icon{border:none!important;background:none!important;}
.zt-feature__icon img{width:30px;height:30px;object-fit:contain;}

/* Icon image overrides for PNG/SVG files */
.zts-card__icon img { width: 90px; height: 90px; object-fit: contain; }
.zts-card__arrow img { width: 28px; height: 28px; object-fit: contain; }
.zts-badge img { width: 20px; height: 20px; object-fit: contain; flex-shrink: 0; }
.zts-soc-pill__icon img { width: 36px; height: 36px; object-fit: contain; }
.zt-badge__icon { border: none !important; background: none !important; }
.zt-badge__icon img { width: 38px; height: 38px; object-fit: contain; }
.zt-feature__icon { border: none !important; background: none !important; }
.zt-feature__icon img { width: 30px; height: 30px; object-fit: contain; }

:root{--y:#f6a800}

  .promo-card{
    display:flex;align-items:stretch;
    background:#161616;
    border:1px solid #2a2a2a;
    border-radius:22px;overflow:hidden;
    width:100%;
    min-height:360px;
    position:relative;
  }

  /* Sparkle bg glow */
  .promo-card::before{
    content:'';position:absolute;inset:0;
    background:radial-gradient(ellipse at 72% 38%, rgba(246,168,0,.10) 0%, transparent 60%);
    pointer-events:none;z-index:0;
  }

  /* Sparkles */
  .sparkles{position:absolute;inset:0;pointer-events:none;z-index:1;overflow:hidden}
  .sparkle{position:absolute;width:3px;height:3px;border-radius:50%;background:var(--y);opacity:0}
  .sparkle:nth-child(1){top:12%;left:60%;width:2px;height:2px;animation:twinkle 3s 0.2s infinite}
  .sparkle:nth-child(2){top:8%;left:75%;width:3px;height:3px;animation:twinkle 4s 1s infinite}
  .sparkle:nth-child(3){top:20%;left:88%;width:2px;height:2px;animation:twinkle 3.5s 0.5s infinite}
  .sparkle:nth-child(4){top:35%;left:92%;width:1.5px;height:1.5px;animation:twinkle 2.5s 1.5s infinite}
  .sparkle:nth-child(5){top:6%;left:68%;width:1.5px;height:1.5px;animation:twinkle 4s 0.8s infinite}
  .sparkle:nth-child(6){top:55%;left:96%;width:2px;height:2px;animation:twinkle 3s 2s infinite}
  .sparkle:nth-child(7){top:70%;left:85%;width:1px;height:1px;animation:twinkle 3.5s 0.3s infinite;opacity:0}
  .sparkle:nth-child(8){top:25%;left:98%;width:2px;height:2px;animation:twinkle 2.8s 1.2s infinite}
  .sparkle:nth-child(9){top:80%;left:90%;width:1.5px;height:1.5px;animation:twinkle 4s 0.6s infinite}
  @keyframes twinkle{0%,100%{opacity:0;transform:scale(.5)}50%{opacity:.9;transform:scale(1)}}

  /* LEFT */
  .promo-card__left{
    flex:1;padding:36px 40px;
    display:flex;flex-direction:column;justify-content:center;
    position:relative;z-index:2;
    min-width:0;
  }

  /* Badge */
  .promo-card__badge{
    display:inline-flex;align-items:center;gap:10px;
    background:var(--y);color:#000;font-size:12px;font-weight:700;
    padding:7px 14px 7px 18px;border-radius:30px;
    margin-bottom:20px;width:fit-content;letter-spacing:.2px;
  }
  .badge-icon{width:20px;height:20px;background:#000;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .badge-icon svg{width:11px;height:11px;stroke:#f6a800;fill:none;stroke-width:2}

  /* Title */
  .promo-card__title{
    font-size:38px;font-weight:900;line-height:1.1;
    color:#fff;margin-bottom:12px;letter-spacing:-.5px;
  }
  .promo-card__title .hl{color:var(--y)}

  /* Divider */
  .promo-card__divider{width:44px;height:4px;background:var(--y);border-radius:2px;margin-bottom:18px}

  /* Text */
  .promo-card__text{color:#aaa;font-size:13.5px;line-height:1.75;margin-bottom:26px;max-width:420px;font-weight:400}

  /* Features */
  .promo-card__features{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;margin-bottom:28px;align-items:center}
  .feat-sep{display:none}
  .promo-feat{display:flex;align-items:center;gap:10px}
  .promo-feat__icon{width:38px;height:38px;border-radius:50%;border:1.5px solid #3a3a3a;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .promo-feat__icon svg{width:16px;height:16px;stroke:var(--y);fill:none;stroke-width:2}
  .promo-feat strong{display:block;font-size:12px;font-weight:800;color:#fff;line-height:1.3}
  .promo-feat span{display:block;font-size:11px;color:#666;line-height:1.3}

  /* CTA */
  .promo-card__cta{display:flex;align-items:center;gap:26px}
  .promo-card__btn{
    display:inline-flex;align-items:center;gap:10px;
    background:var(--y);color:#000;font-size:15px;font-weight:800;
    padding:15px 28px;border-radius:12px;text-decoration:none;
    cursor:pointer;transition:.2s;white-space:nowrap;font-family:'Montserrat',sans-serif;border:none;
  }
  .promo-card__btn svg{stroke:#000;fill:none;stroke-width:2;width:18px;height:18px}
  .promo-card__btn:hover{background:#e09a00;transform:translateY(-2px)}

  .promo-code-block{display:flex;align-items:center;gap:4px}
  .code-arrow{color:var(--y);opacity:.75;margin-right:2px;margin-top:6px}
  .promo-card__code{display:flex;flex-direction:column}
  .promo-card__code-label{font-size:11.5px;color:#888;margin-bottom:2px;font-weight:400}
  .promo-card__code-value{font-size:20px;font-weight:900;color:#fff;letter-spacing:.5px}

  /* RIGHT */
  .promo-card__right{
    flex-shrink:0;
    width: 500px;
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
    z-index:2;
    background:radial-gradient(ellipse at 50% 40%, rgba(246,168,0,.09) 0%, transparent 70%);
  }

  .gift-wrap{
    position:relative;
    width:100%;
    height:100%;
    min-height:300px;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .gift-img{
    width:100%;height:100%;
    object-fit:cover;
    object-position:center;
    position:relative;z-index:1;
    display:block;
  }

  /* Price tag overlay */
  .gift-tag{
    position:absolute;bottom:28px;right:20px;
    background:rgba(20,20,20,.92);border:1.5px solid #f6a800;border-radius:14px;
    padding:10px 18px;z-index:3;text-align:center;
    box-shadow:0 4px 24px rgba(0,0,0,.7);
    backdrop-filter:blur(4px);
  }
  .gift-tag__pct{font-size:30px;font-weight:900;color:var(--y);line-height:1}
  .gift-tag__label{font-size:12px;font-weight:600;color:var(--y);margin-top:2px}
  /* tag notch */
  .gift-tag::before{
    content:'';position:absolute;top:-8px;left:50%;transform:translateX(-50%);
    width:12px;height:12px;border-radius:50%;background:#1a1a1a;border:2px solid #2e2e2e;
  }
  /* string */
  .gift-tag-string{
    position:absolute;bottom:108px;right:62px;
    width:2px;height:40px;background:rgba(246,168,0,.35);z-index:1;
    transform:rotate(6deg);transform-origin:top center;
  }

/* ══════════════════════════════════════════
   MOBILE HEADER & BURGER
══════════════════════════════════════════ */
.mob-header-right { display: none; align-items: center; gap: 10px; margin-left: auto; }
.mob-phone-btn { display: flex; align-items: center; justify-content: center; width: 38px; height: 38px; }
.mob-phone-btn img { width: 26px; height: 26px; }

/* Burger */
.burger { display: flex; flex-direction: column; justify-content: center; gap: 5px; width: 38px; height: 38px; background: none; border: none; cursor: pointer; padding: 6px; }
.burger span { display: block; height: 2px; background: #fff; border-radius: 2px; transition: .25s; }
.burger--open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.burger--open span:nth-child(2) { opacity: 0; }
.burger--open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile nav drawer */
.mob-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: #0f0f0f; border-bottom: 1px solid #222; z-index: 200; padding: 16px 10px 20px; }
.mob-nav--open { display: block; }
.mob-nav__links { display: flex; flex-direction: column; gap: 0; }
.mob-nav__links a { display: block; color: #ccc; font-size: 16px; font-weight: 500; padding: 14px 10px; border-bottom: 1px solid #1e1e1e; transition: color .2s; }
.mob-nav__links a:last-child { border-bottom: none; }
.mob-nav__links a:hover { color: var(--yellow); }
.mob-nav__socials { display: flex; gap: 14px; padding: 16px 10px 0; }
.mob-nav__socials a img { width: 28px; height: 28px; }

/* Logo text fallback */
.logo__text { font-size: 20px; font-weight: 900; color: var(--yellow); letter-spacing: 1px; }
.logo__img { height: 38px; width: auto; }

/* header-btn desktop only label */
.header-btn--desk { background: var(--yellow); color: #000; font-weight: 700; font-size: 14px; padding: 10px 20px; border-radius: 8px; white-space: nowrap; transition: .2s; }
.header-btn--desk:hover { background: var(--yellow-dark); }

/* ══════════════════════════════════════════
   GLOBAL TYPOGRAPHY
══════════════════════════════════════════ */
.section-title { font-size: 22px !important; }
.info-card-title, .transfer-name, .tariff-card h3, .review-name,
.step-title, .article-title, h3, h4 { font-size: 18px; }
p, .section-sub, .about-text, .review-text, .faq-answer,
.info-card-text, .promo-card__text, .transfer-price, .step-text { line-height: 1.3; }

/* Phone label: shown on desktop, hidden on mobile */
.zt-phone-label { }

/* Hide "Все направления" on mobile */
@media (max-width: 768px) { .zt-hide-mob { display: none !important; } }

/* ══════════════════════════════════════════
   MOBILE OVERRIDES ≤ 768px
══════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Side padding everywhere = 10px */
  .container, .header-inner, .topbar .inner,
  .zt-hero__inner, .zt-hero__features-inner,
  .footer-grid, .breadcrumb .inner { padding-left: 10px !important; padding-right: 10px !important; }

  /* Hide topbar completely */
  .topbar { display: none !important; }

  /* Show mobile header elements, hide desktop ones */
  .mob-header-right { display: flex !important; }
  .header-btn--desk { display: none !important; }
  .nav { display: none !important; }
  .header-inner { padding-left: 10px !important; padding-right: 10px !important; }

  /* Header: logo left, mob-right right */
  .header-inner { justify-content: space-between; }

  /* ── HERO badges: one row, wrap ── */
  .zt-hero__badges {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-bottom: 16px;
  }
  .zt-badge {
    flex: 1 1 calc(50% - 8px);
    min-width: 120px;
    padding: 8px;
    background: rgba(255,255,255,.04);
    border-radius: 8px;
  }
  .zt-badge__icon { width: 28px; height: 28px; }
  .zt-badge__icon img { width: 24px; height: 24px; }

  /* ── HERO CTA buttons: one row ── */
  .zt-hero__cta {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
  }
  /* Phone button: icon only on mobile */
  .zt-cta-btn--phone-only .zt-phone-label { display: none; }
  .zt-cta-btn--phone-only {
    padding: 11px 14px !important;
    min-width: 0;
    flex-shrink: 0;
  }
  .zt-cta-btn { flex: 1; justify-content: center; font-size: 13px; padding: 11px 10px; }

  /* ── Price table: visible scrollbar ── */
  .prices-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--yellow) #222;
    border-radius: 12px;
    border: 1px solid #2a2a2a;
  }
  .prices-table-wrap::-webkit-scrollbar { height: 6px; }
  .prices-table-wrap::-webkit-scrollbar-track { background: #1a1a1a; border-radius: 3px; }
  .prices-table-wrap::-webkit-scrollbar-thumb { background: var(--yellow); border-radius: 3px; }

  /* ── Gift / promo block ── */
  .promo-card {
    flex-direction: column !important;
    min-height: auto !important;
  }
  .promo-card__right {
    width: 100% !important;
    height: 220px !important;
    order: -1;
  }
  .promo-card__left {
    padding: 20px 14px !important;
  }
  .promo-card__title { font-size: 26px !important; }
  .promo-card__features { grid-template-columns: 1fr !important; }
  .promo-card__cta { flex-direction: column !important; align-items: flex-start !important; gap: 14px !important; }
  .promo-card__btn { width: 100% !important; justify-content: center !important; }

  /* Gift block phone: show number in two lines */
  .gift-phone-mob {
    display: flex !important;
    flex-direction: column;
    font-size: 15px;
    font-weight: 700;
    color: var(--yellow);
    line-height: 1.3;
    margin-top: 12px;
  }
  .gift-phone-mob span { color: #aaa; font-size: 12px; font-weight: 400; }

  /* ── Section headings & text ── */
  .section-title { font-size: 18px !important; }
  h3, .contacts-title, .booking-form h3, .route-stops h4 { font-size: 18px !important; }
  p, .about-text, .section-sub, .review-text, .faq-answer,
  .info-card-text, .promo-card__text, .step-text, .dir-sub { font-size: 14px !important; line-height: 1.3 !important; }

  /* Side padding for all sections */
  .section { padding: 36px 0; }
}


/* ══════════════════════════════════════════
   GIFT BLOCK PHONE — mobile show/hide
══════════════════════════════════════════ */
.gift-phone-mob { display: none; }
@media (max-width: 768px) {
  .gift-phone-mob {
    display: flex !important;
    flex-direction: column;
    gap: 2px;
    font-size: 17px;
    font-weight: 800;
    color: var(--yellow);
    text-decoration: none;
    margin-top: 14px;
    line-height: 1.3;
    word-break: break-all;
  }
  .gift-phone-mob span {
    color: #aaa;
    font-size: 12px;
    font-weight: 400;
  }
}

/* ══════════════════════════════════════════
   HERO CTA phone: show number on desktop, icon-only mobile
══════════════════════════════════════════ */
@media (min-width: 769px) {
  .zt-cta-btn--phone-only .zt-phone-label { display: inline; }
  /* Phone icon in CTA: use ic-phone.svg inline style, keep SVG as fallback */
}
@media (max-width: 768px) {
  .zt-cta-btn--phone-only .zt-phone-label { display: none !important; }
  .zt-cta-btn--phone-only {
    flex: 0 0 48px !important;
    padding: 11px 12px !important;
    min-width: 0;
  }
}

/* ══════════════════════════════════════════
   TOPBAR phone number: hide on mobile
══════════════════════════════════════════ */
@media (max-width: 768px) {
  /* topbar already hidden; also hide phone from CTA buttons text globally */
  .zt-hero__cta .zt-cta-btn--phone-only .zt-phone-label { display: none; }
}

/* ══════════════════════════════════════════
   GLOBAL TEXT LINE-HEIGHT 1.3
══════════════════════════════════════════ */
p { line-height: 1.3; }
.about-text { line-height: 1.3 !important; }
.review-text { line-height: 1.3 !important; }
.faq-answer { line-height: 1.3 !important; }
.info-card-text { line-height: 1.3 !important; }
.promo-card__text { line-height: 1.3 !important; }
.dir-sub { line-height: 1.3 !important; }
.step-text { line-height: 1.3 !important; }
.zt-hero__sub { line-height: 1.3 !important; }

/* ══════════════════════════════════════════
   SECTION HEADINGS: 18-20px inside blocks
══════════════════════════════════════════ */
.info-card-title { font-size: 18px; }
.transfer-name { font-size: 16px; }
.review-name { font-size: 15px; }
.step-title { font-size: 18px; }
.article-title { font-size: 16px; }
.tariff-card h3, .tp-name { font-size: 15px; }
.contacts-title { font-size: 20px; }
.booking-form h3 { font-size: 18px; }
.route-stops h4 { font-size: 18px; }


/* ══════════════════════════════════════════
   PRICE TABLE TOGGLE
══════════════════════════════════════════ */
.price-row--hidden { display: none !important; }
.table-toggle-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    border: 1.5px solid #3a3a3a;
    color: #ccc;
    font-size: 14px;
    font-weight: 600;
    padding: 10px 22px;
    border-radius: 8px;
    cursor: pointer;
    font-family: 'Inter', sans-serif;
    transition: .2s;
}
.table-toggle-btn:hover {
    border-color: var(--yellow);
    color: var(--yellow);
}
.table-toggle-btn svg {
    flex-shrink: 0;
    transition: transform .25s;
}

/* ══════════════════════════════════════════
   CONTACTS GRID — mobile column
══════════════════════════════════════════ */
@media (max-width: 768px) {
    .contacts-grid {
        flex-direction: column !important;
        display: flex !important;
    }
    .contact-item {
        width: 100%;
    }
}

/* ══════════════════════════════════════════
   BLOG CARD image stretch fix
══════════════════════════════════════════ */
.blog-card__img {
    overflow: hidden;
}
.blog-card__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .3s;
    display: block;
}
.blog-card:hover .blog-card__img img {
    transform: scale(1.04);
}


/* ══════════════════════════════════════════
   PROMO BLOCK — mobile contacts block
══════════════════════════════════════════ */
.promo-contacts-mob { display: none; }

@media (max-width: 768px) {
  .promo-contacts-mob {
    display: block;
    margin-top: 20px;
    padding-top: 18px;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .promo-contacts-mob__title {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 14px;
  }
  .promo-contacts-mob__grid {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .promo-contact-item {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: inherit;
    transition: .15s;
  }
  .promo-contact-item:hover { color: var(--yellow); }
  .promo-contact-item img { flex-shrink: 0; }
  .promo-contact-item__name { font-size: 15px; font-weight: 700; color: #fff; line-height: 1.2; }
  .promo-contact-item__sub { font-size: 12px; color: #666; margin-top: 1px; }

  /* Mobile header: icons smaller, tighter gap */
  .mob-header-right { gap: 4px !important; }
  .mob-phone-btn { width: 32px; height: 32px; }
  .mob-phone-btn img { width: 22px; height: 22px; }
}

/* ══════════════════════════════════════════
   PROMO INNER — contacts embedded below gift
══════════════════════════════════════════ */
.promo-contacts-inner {
    margin-top: 24px;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.promo-contacts-inner__title {
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 16px;
}
.promo-contacts-inner__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 32px;
}
.promo-contact-item {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    color: inherit;
    transition: .15s;
}
.promo-contact-item:hover { color: var(--yellow); }
.promo-contact-item img { flex-shrink: 0; }
.promo-contact-item__name { font-size: 15px; font-weight: 700; color: #fff; line-height: 1.2; }
.promo-contact-item__sub { font-size: 12px; color: #666; margin-top: 2px; }

/* Mobile: stack items vertically */
@media (max-width: 768px) {
    .promo-contacts-inner { margin-top: 18px; padding-top: 16px; }
    .promo-contacts-inner__title { font-size: 14px; margin-bottom: 12px; }
    .promo-contacts-inner__grid { flex-direction: column; gap: 12px; }
    .mob-header-right { gap: 6px !important; }
    .mob-phone-btn { width: 34px; height: 34px; display: flex; align-items: center; justify-content: center; }
    .mob-phone-btn img { width: 22px; height: 22px; }
	img.gift-img {
    width: auto;
}

.gift-wrap {
    min-height: 200px;
}
}
span.zts-soc-pill__label {
    display: none;
}
/* ══════════════════════════════════════════
   PROMO BONUS TEXT
══════════════════════════════════════════ */
.promo-bonus-text {
    color: #666;
    font-size: 16px;
    margin: 0;
    line-height: 1.3;
    font-style: italic;
}

/* ══════════════════════════════════════════
   REVIEWS GRID
══════════════════════════════════════════ */
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}
.review-card {
    background: #181818;
    border: 1px solid #2a2a2a;
    border-radius: 16px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: border-color .2s;
}
.review-card:hover { border-color: #3a3a3a; }
.review-stars { color: #f6a800; font-size: 16px; letter-spacing: 2px; }
.review-text { color: #bbb; font-size: 14px; line-height: 1.6; flex: 1; margin: 0; }
.review-author { display: flex; align-items: center; gap: 12px; margin-top: 4px; }
.review-avatar {
    width: 40px; height: 40px; border-radius: 50%;
    background: linear-gradient(135deg, #f6a800, #e68900);
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: 16px; color: #000; flex-shrink: 0;
}
.review-name { font-size: 14px; font-weight: 700; color: #fff; }
.review-date { font-size: 12px; color: #555; margin-top: 2px; }
@media (max-width: 768px) {
    .reviews-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   ORDER POPUP
══════════════════════════════════════════ */
.order-popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    backdrop-filter: blur(4px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s;
}
.order-popup-overlay--open {
    opacity: 1;
    pointer-events: all;
}
.order-popup {
    background: #181818;
    border: 1px solid #2a2a2a;
    border-radius: 20px;
    padding: 36px 32px 32px;
    width: 100%;
    max-width: 420px;
    position: relative;
    transform: translateY(16px);
    transition: transform .25s;
    text-align: center;
}
.order-popup-overlay--open .order-popup {
    transform: translateY(0);
}
.order-popup__close {
    position: absolute;
    top: 14px; right: 16px;
    background: none;
    border: none;
    color: #555;
    font-size: 18px;
    cursor: pointer;
    line-height: 1;
    padding: 4px 8px;
    border-radius: 6px;
    transition: .15s;
}
.order-popup__close:hover { color: #fff; background: #2a2a2a; }
.order-popup__title {
    font-size: 22px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 8px;
}
.order-popup__sub {
    color: #666;
    font-size: 14px;
    margin-bottom: 28px;
    line-height: 1.4;
}
.order-popup__btns {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.order-popup__btn {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 20px;
    border-radius: 12px;
    text-decoration: none;
    font-size: 15px;
    font-weight: 700;
    transition: .2s;
    border: 1.5px solid transparent;
}
.order-popup__btn--tg {
    background: rgba(42,161,255,.1);
    border-color: rgba(42,161,255,.25);
    color: #60c8ff;
}
.order-popup__btn--tg:hover { background: rgba(42,161,255,.18); border-color: rgba(42,161,255,.5); }
.order-popup__btn--max {
    background: rgba(233,30,140,.1);
    border-color: rgba(233,30,140,.25);
    color: #ff6ec4;
}
.order-popup__btn--max:hover { background: rgba(233,30,140,.18); border-color: rgba(233,30,140,.5); }
.order-popup__btn--phone {
    background: rgba(246,168,0,.1);
    border-color: rgba(246,168,0,.3);
    color: var(--yellow);
}
.order-popup__btn--phone:hover { background: rgba(246,168,0,.18); border-color: rgba(246,168,0,.6); }
.order-popup__btn img { flex-shrink: 0; }
.order-popup__btn span { flex: 1; text-align: left; }
@media (max-width: 480px) {
    .order-popup { padding: 28px 20px 24px; border-radius: 16px; }
    .order-popup__title { font-size: 18px; }
}


/* ══════════════════════════════════════════
   CTA PHONE FORM
══════════════════════════════════════════ */
.cta-phone-form { display: flex; flex-direction: column; gap: 12px; align-items: center; margin: 20px 0; }
.cta-phone-row { display: flex; gap: 10px; width: 100%; max-width: 480px; }
.cta-phone-input {
    flex: 1;
    background: #1a1a1a;
    border: 1.5px solid #2a2a2a;
    border-radius: 10px;
    color: #fff;
    font-size: 15px;
    padding: 13px 18px;
    outline: none;
    transition: border-color .2s;
    font-family: inherit;
}
.cta-phone-input:focus { border-color: var(--yellow); }
.cta-phone-btn { padding: 13px 22px; font-size: 15px; border-radius: 10px; white-space: nowrap; }
.cta-agree-label {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 12px;
    color: #666;
    cursor: pointer;
    max-width: 480px;
    line-height: 1.4;
}
.cta-agree-label a { color: #888; }
.cta-agree-label a:hover { color: var(--yellow); }
.cta-agree-check { margin-top: 2px; accent-color: var(--yellow); flex-shrink: 0; }

/* Hero form consent */
.zt-form-agree {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    font-size: 11px;
    color: #555;
    cursor: pointer;
    margin-bottom: 4px;
    line-height: 1.4;
}
.zt-form-agree a { color: #666; text-decoration: underline; }
.zt-form-agree a:hover { color: var(--yellow); }
.zt-agree-check { margin-top: 2px; accent-color: var(--yellow); flex-shrink: 0; }

/* ══════════════════════════════════════════
   FOOTER COMPANY INFO
══════════════════════════════════════════ */
.footer-company {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid #1e1e1e;
}
.footer-company__name {
    font-size: 12px;
    font-weight: 700;
    color: #aaa;
    margin-bottom: 6px;
}
.footer-company__row {
    font-size: 11px;
    color: #555;
    line-height: 1.6;
}
.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
@media (max-width: 768px) {
    .cta-phone-row { flex-direction: column; }
    .cta-phone-btn { width: 100%; justify-content: center; }
    .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ══════════════════════════════════════════
   COOKIE CONSENT BANNER
══════════════════════════════════════════ */
.cookie-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 99999;
    background: #141414;
    border-top: 1px solid #2a2a2a;
    box-shadow: 0 -8px 32px rgba(0,0,0,.6);
    transform: translateY(100%);
    transition: transform .35s cubic-bezier(.4,0,.2,1);
}
.cookie-banner--show { transform: translateY(0); }
.cookie-banner--hide { transform: translateY(110%); }

.cookie-banner__inner {
    max-width: 1280px;
    margin: 0 auto;
    padding: 16px 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.cookie-banner__text {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    flex: 1;
    min-width: 240px;
    font-size: 13px;
    color: #aaa;
    line-height: 1.5;
}
.cookie-banner__icon { flex-shrink: 0; margin-top: 1px; }
.cookie-banner__link { color: var(--yellow); text-decoration: underline; }
.cookie-banner__link:hover { color: #fff; }

.cookie-banner__btns {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
}
.cookie-banner__accept {
    background: var(--yellow);
    color: #000;
    font-weight: 700;
    font-size: 13px;
    padding: 10px 20px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-family: inherit;
    transition: .2s;
    white-space: nowrap;
}
.cookie-banner__accept:hover { background: #e09900; }
.cookie-banner__decline {
    background: transparent;
    color: #666;
    font-size: 13px;
    padding: 10px 16px;
    border: 1px solid #333;
    border-radius: 8px;
    cursor: pointer;
    font-family: inherit;
    transition: .2s;
    white-space: nowrap;
}
.cookie-banner__decline:hover { color: #aaa; border-color: #555; }

@media (max-width: 600px) {
    .cookie-banner__inner { padding: 14px 10px; gap: 12px; }
    .cookie-banner__btns { width: 100%; }
    .cookie-banner__accept, .cookie-banner__decline { flex: 1; text-align: center; }
}

/* ══════════════════════════════════════════
   DIRECTION TARIFF TABLE
══════════════════════════════════════════ */
.dir-tariff-section { background: #0f0f0f; }
.dir-tariff-wrap {
    overflow-x: auto;
    border-radius: 14px;
    border: 1px solid #222;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--yellow) #1a1a1a;
}
.dir-tariff-wrap::-webkit-scrollbar { height: 5px; }
.dir-tariff-wrap::-webkit-scrollbar-track { background: #1a1a1a; }
.dir-tariff-wrap::-webkit-scrollbar-thumb { background: var(--yellow); border-radius: 3px; }

.dir-tariff-table {
    width: 100%;
    border-collapse: collapse;
    min-width: 680px;
}
.dir-tariff-table thead tr {
    background: #181818;
    border-bottom: 1px solid #2a2a2a;
}
.dir-tariff-table th {
    padding: 14px 16px;
    font-size: 13px;
    font-weight: 600;
    color: #888;
    text-align: left;
    white-space: nowrap;
}
.dir-tariff-table th.col-car { color: var(--yellow); min-width: 220px; }
.dir-tariff-table th.col-icon {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}
.dir-tariff-table th.col-icon svg { display: block; margin: 0 auto 4px; stroke: var(--yellow); }
.dir-tariff-table th.col-icon span { display: block; font-size: 11px; }
.dir-tariff-table th.col-price,
.dir-tariff-table th.col-note { text-align: center; }
.dir-tariff-table th.col-order { text-align: center; color: var(--yellow); }

.dir-tariff-row {
    border-bottom: 1px solid #1e1e1e;
    transition: background .15s;
}
.dir-tariff-row:last-child { border-bottom: none; }
.dir-tariff-row:hover { background: #161616; }

.dir-tariff-table td {
    padding: 18px 16px;
    font-size: 14px;
    color: #ccc;
    vertical-align: middle;
}
.cell-car {
    display: flex !important;
    align-items: center;
    gap: 16px;
    min-width: 220px;
}
.dir-tariff-carimg {
    width: 110px;
    height: 68px;
    object-fit: contain;
    flex-shrink: 0;
    filter: drop-shadow(0 2px 8px rgba(0,0,0,.5));
}
.dir-tariff-emoji { font-size: 36px; }
.dir-tariff-nameblock { display: flex; flex-direction: column; gap: 4px; }
.dir-tariff-name { font-size: 15px; font-weight: 800; color: #fff; letter-spacing: .5px; }
.dir-tariff-price { font-size: 16px; font-weight: 700; color: var(--yellow); }
.cell-price-col { text-align: center; font-size: 15px; color: #aaa; white-space: nowrap; }
.cell-price-col strong { color: #fff; }
.cell-data { text-align: center; color: #aaa; }
.cell-note-td { text-align: center; color: #777; font-size: 13px; }
.cell-order { text-align: center; }
.dir-tariff-btn {
    background: var(--yellow);
    color: #000;
    font-weight: 800;
    font-size: 14px;
    padding: 12px 22px;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    white-space: nowrap;
    font-family: inherit;
    transition: .2s;
}
.dir-tariff-btn:hover { background: #e09900; transform: translateY(-1px); }

/* Footer features */
.dir-tariff-footer {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin-top: 20px;
    background: #181818;
    border: 1px solid #222;
    border-radius: 14px;
    overflow: hidden;
}
.dir-tariff-feat {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 20px 22px;
    border-right: 1px solid #222;
    font-size: 13px;
    color: #888;
    line-height: 1.5;
}
.dir-tariff-feat:last-child { border-right: none; }
.dir-tariff-feat img { flex-shrink: 0; margin-top: 2px; }

@media (max-width: 768px) {
    .dir-tariff-footer { grid-template-columns: 1fr; }
    .dir-tariff-feat { border-right: none; border-bottom: 1px solid #222; }
    .dir-tariff-feat:last-child { border-bottom: none; }
    .cell-price-col { display: none; } /* price already shown in car cell */
}

/* ══════════════════════════════════════════
   DIRECTION INFO SECTION
══════════════════════════════════════════ */
.dir-info-section { background: #111; }

.dir-info-wrap {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: 48px;
    align-items: start;
}

/* Left */
.dir-info-tag {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    color: var(--yellow);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 16px;
}
.dir-info-tag svg { stroke: var(--yellow); }

.dir-info-title {
    font-size: 32px;
    font-weight: 900;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 12px;
}
.dir-info-title-hl { color: var(--yellow); }
.dir-info-divider {
    width: 48px;
    height: 3px;
    background: var(--yellow);
    border-radius: 2px;
    margin-bottom: 24px;
}
.dir-info-text { color: #aaa; font-size: 15px; line-height: 1.7; margin-bottom: 28px; }
.dir-info-text p { margin-bottom: 14px; }
.dir-info-text p:last-child { margin-bottom: 0; }
.dir-info-text strong { color: #fff; font-weight: 700; }

.dir-info-feats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 24px;
    padding-top: 20px;
    border-top: 1px solid #222;
}
.dir-info-feat {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}
.dir-info-feat img { flex-shrink: 0; margin-top: 2px; }
.dir-info-feat strong { display: block; font-size: 13px; font-weight: 700; color: #fff; margin-bottom: 2px; }
.dir-info-feat span { font-size: 12px; color: #666; line-height: 1.4; }

/* Right */
.dir-info-right {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
}
.dir-info-bgimg {
    width: 100%;
    height: 280px;
    object-fit: cover;
    object-position: center;
    display: block;
    filter: brightness(.55);
}
.dir-info-card {
    background: rgba(15,15,15,.92);
    border: 1px solid #2a2a2a;
    border-radius: 12px;
    padding: 20px;
    margin: -60px 16px 16px;
    position: relative;
    backdrop-filter: blur(8px);
}
.dir-info-card__title {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 14px;
}
.dir-info-card__list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.dir-info-card__list li {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid #1e1e1e;
}
.dir-info-card__list li:last-child { border-bottom: none; }
.dir-info-card__list svg { stroke: var(--yellow); flex-shrink: 0; }
.dir-info-card__list span { font-size: 11px; color: #666; display: block; margin-bottom: 2px; }
.dir-info-card__list strong { font-size: 14px; font-weight: 700; color: var(--yellow); display: block; }

/* Bottom alert bar */
.dir-info-alert {
    display: flex;
    align-items: center;
    gap: 18px;
    background: #181818;
    border: 1px solid #2a2a2a;
    border-radius: 12px;
    padding: 20px 24px;
    margin-top: 28px;
    flex-wrap: wrap;
}
.dir-info-alert img { flex-shrink: 0; }
.dir-info-alert__text { flex: 1; min-width: 200px; }
.dir-info-alert__text strong { display: block; font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.dir-info-alert__text span { font-size: 13px; color: #666; }
.dir-info-alert__btn {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--yellow);
    color: #000;
    font-weight: 800;
    font-size: 14px;
    padding: 12px 22px;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    transition: .2s;
    flex-shrink: 0;
}
.dir-info-alert__btn:hover { background: #e09900; }

@media (max-width: 900px) {
    .dir-info-wrap { grid-template-columns: 1fr; gap: 28px; }
    .dir-info-right { order: -1; }
    .dir-info-bgimg { height: 200px; }
    .dir-info-card { margin: -40px 12px 12px; }
    .dir-info-title { font-size: 24px; }
    .dir-info-feats { grid-template-columns: 1fr; gap: 10px; }
}
@media (max-width: 600px) {
    .dir-info-alert { flex-direction: column; align-items: flex-start; }
    .dir-info-alert__btn { width: 100%; justify-content: center; }
}

/* ══════════════════════════════════════════
   DIRECTION — ЧТО ВХОДИТ В СТОИМОСТЬ
══════════════════════════════════════════ */
.dir-included-section { background: #0d0d0d; }

.dir-included-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 24px;
}
.dir-included-line {
    flex: 1;
    max-width: 180px;
    height: 1px;
    background: linear-gradient(90deg, transparent, #3a3a3a);
}
.dir-included-header .dir-included-line:last-child {
    background: linear-gradient(270deg, transparent, #3a3a3a);
}
.dir-included-circle {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: 1.5px solid var(--yellow);
    background: rgba(246,168,0,.08);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.dir-included-circle svg { stroke: var(--yellow); }

.dir-included-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-bottom: 28px;
}

.dir-included-card {
    background: #161616;
    border: 1px solid #222;
    border-radius: 16px;
    padding: 28px 20px 24px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    transition: border-color .2s, transform .2s;
}
.dir-included-card:hover {
    border-color: #333;
    transform: translateY(-3px);
}

.dir-included-icon {
    width: 60px;
    height: 60px;
    border-radius: 16px;
    background: rgba(246,168,0,.08);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}
.dir-included-icon img { width: 32px; height: 32px; object-fit: contain; }

.dir-included-title {
    font-size: 17px;
    font-weight: 800;
    color: #fff;
    margin-bottom: 10px;
    line-height: 1.3;
}

.dir-included-divider {
    width: 28px;
    height: 2px;
    background: var(--yellow);
    border-radius: 2px;
    margin-bottom: 12px;
}

.dir-included-text {
    font-size: 13px;
    color: #777;
    line-height: 1.6;
    margin: 0;
}

.dir-included-note {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 15px;
    color: #aaa;
    justify-content: center;
}
.dir-included-note img { flex-shrink: 0; }
.dir-included-note strong { color: #fff; }

@media (max-width: 1024px) {
    .dir-included-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .dir-included-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
    .dir-included-card { padding: 20px 14px; }
    .dir-included-icon { width: 48px; height: 48px; margin-bottom: 14px; }
    .dir-included-title { font-size: 14px; }
    .dir-included-text { font-size: 12px; }
}
@media (max-width: 400px) {
    .dir-included-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════
   PAGE: О КОМПАНИИ
══════════════════════════════════════════ */
.about-hero-section { background: #0f0f0f; padding: 52px 0 0; }

.about-hero-wrap {
    display: grid;
    grid-template-columns: 1fr 520px;
    gap: 56px;
    align-items: start;
    margin-bottom: 40px;
}

/* Left */
.about-hero-tag {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: var(--yellow);
    margin-bottom: 16px;
    text-transform: uppercase;
}
.about-hero-title {
    font-size: 40px;
    font-weight: 900;
    color: #fff;
    line-height: 1.15;
    margin-bottom: 24px;
}
.about-hero-yellow { color: var(--yellow); }
.about-hero-text p {
    font-size: 15px;
    color: #aaa;
    line-height: 1.7;
    margin-bottom: 14px;
}
.about-hero-text p:last-child { margin-bottom: 0; }

/* Right */
.about-hero-img-wrap { position: relative; border-radius: 16px; overflow: hidden; }
.about-hero-img { width: 100%; height: 360px; object-fit: cover; object-position: center; display: block; }
.about-safety-card {
    position: absolute;
    bottom: 16px; right: 16px;
    background: rgba(15,15,15,.88);
    backdrop-filter: blur(10px);
    border: 1px solid #2a2a2a;
    border-radius: 12px;
    padding: 14px 18px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    max-width: 300px;
}
.about-safety-icon { flex-shrink: 0; margin-top: 2px; }
.about-safety-title { font-size: 14px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.about-safety-text { font-size: 12px; color: #888; line-height: 1.4; }

/* Stats row */
.about-stats-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border: 1px solid #222;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 0;
}
.about-stat-card {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 28px 24px;
    border-right: 1px solid #222;
    background: #141414;
}
.about-stat-card:last-child { border-right: none; }
.about-stat-icon { flex-shrink: 0; margin-top: 2px; }
.about-stat-val { font-size: 22px; font-weight: 900; color: #fff; line-height: 1.1; }
.about-stat-label { font-size: 14px; font-weight: 600; color: var(--yellow); margin-bottom: 8px; }
.about-stat-text { font-size: 12px; color: #666; line-height: 1.5; margin: 0; }

/* Bottom bar */
.about-bottom-bar {
    display: flex;
    align-items: center;
    gap: 0;
    background: #181818;
    border: 1px solid #222;
    border-top: none;
    flex-wrap: wrap;
}
.about-bar-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 20px 24px;
    border-right: 1px solid #222;
    flex: 1;
    min-width: 160px;
}
.about-bar-item svg { flex-shrink: 0; }
.about-bar-item strong { display: block; font-size: 14px; color: #fff; }
.about-bar-item span { font-size: 12px; color: #666; }
.about-bar-cta {
    background: var(--yellow);
    color: #000;
    font-weight: 800;
    font-size: 15px;
    padding: 20px 28px;
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    white-space: nowrap;
    transition: .2s;
    flex-shrink: 0;
}
.about-bar-cta:hover { background: #e09900; }

/* Admin: extra text fields */
@media (max-width: 1100px) {
    .about-hero-wrap { grid-template-columns: 1fr 400px; gap: 36px; }
    .about-stats-row { grid-template-columns: 1fr 1fr; }
    .about-stat-card:nth-child(2) { border-right: none; }
    .about-stat-card:nth-child(3) { border-right: 1px solid #222; border-top: 1px solid #222; }
    .about-stat-card:nth-child(4) { border-right: none; border-top: 1px solid #222; }
}
@media (max-width: 768px) {
    .about-hero-wrap { grid-template-columns: 1fr; gap: 28px; }
    .about-hero-right { order: -1; }
    .about-hero-img { height: 240px; }
    .about-hero-title { font-size: 28px; }
    .about-stats-row { grid-template-columns: 1fr 1fr; }
    .about-stat-card { padding: 18px 14px; }
    .about-bottom-bar { flex-direction: column; align-items: stretch; }
    .about-bar-item { border-right: none; border-bottom: 1px solid #222; }
    .about-bar-cta { justify-content: center; border-top: 1px solid #222; }
}
@media (max-width: 480px) {
    .about-stats-row { grid-template-columns: 1fr; }
    .about-stat-card { border-right: none; border-top: 1px solid #222; }
    .about-stat-card:first-child { border-top: none; }
}

/* ══════════════════════════════════════════
   NAV — active page highlight
══════════════════════════════════════════ */
nav a { font-size: 13px; padding: 8px 10px; }
nav a.active, nav a:focus { color: var(--yellow); }
@media (max-width: 1200px) {
    nav a { font-size: 12px; padding: 8px 8px; }
    .header-inner { gap: 16px; }
}

/* ══════════════════════════════════════════
   CITY TAGS — плитка городов на странице города
══════════════════════════════════════════ */
.city-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.city-tag {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: 100px;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: all .18s ease;
    border: 1px solid #2e2e2e;
    background: #1a1a1a;
    color: #ccc;
    white-space: nowrap;
}
.city-tag:hover {
    border-color: var(--yellow);
    color: var(--yellow);
    background: rgba(246,168,0,.08);
}
.city-tag--active {
    border-color: var(--yellow);
    color: #111;
    background: var(--yellow);
    font-weight: 600;
}
.city-tag--active:hover {
    background: #e09900;
    color: #111;
    border-color: #e09900;
}

/* ══ Breadcrumb улучшенный ══ */
.breadcrumb a {
    color: #aaa;
    text-decoration: none;
    transition: color .15s;
}
.breadcrumb a:hover {
    color: var(--yellow);
}

/* ══ City tag — any city call CTA ══ */
.city-tag--any {
    border-color: #3a3a3a;
    background: transparent;
    color: #888;
    gap: 7px;
    font-style: italic;
}
.city-tag--any:hover {
    border-color: var(--yellow);
    color: var(--yellow);
    background: rgba(246,168,0,.06);
}
