/* ДніпрБус — чистий адаптивний CSS. Фірмові кольори: червоний/сірий/синій. */
:root{
  --red:#cb0106; --red-d:#a80105; --blue:#1b4f9c; --ink:#222; --muted:#6b6b6b;
  --grey:#5a5a5a; --bg:#fff; --bg-soft:#f4f5f7; --line:#e3e5e8; --white:#fff;
  --radius:10px; --shadow:0 4px 18px rgba(0,0,0,.08); --max:1160px;
  --ff:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff);color:var(--ink);background:var(--bg);line-height:1.6;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{line-height:1.2;color:var(--ink);margin:.2em 0 .5em}
h1{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h2{font-size:clamp(1.3rem,2.6vw,1.8rem)}
.container{max-width:var(--max);margin:0 auto;padding:0 16px}
.narrow{max-width:840px}
.center{text-align:center}
.lead{font-size:1.12rem;color:#444}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:100}

/* Buttons */
.btn{display:inline-block;padding:12px 22px;border-radius:var(--radius);font-weight:600;
  cursor:pointer;border:2px solid transparent;transition:.15s;text-align:center;line-height:1.1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--accent{background:var(--red);color:#fff;border-color:var(--red)}
.btn--accent:hover{background:var(--red-d);border-color:var(--red-d);color:#fff}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:var(--red);color:var(--red)}
.btn--sm{padding:8px 16px;font-size:.92rem}

/* Header — оформление как в оригинале: светло-серый верх, серая полоса меню */
.site-header{position:sticky;top:0;z-index:40;background:#d2d2d2}
.header-top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px}
.logo img{height:auto;width:210px;max-width:48vw}
.header-actions{display:flex;align-items:center;gap:14px}
.header-phones{display:flex;flex-direction:column;text-align:right;font-weight:700;line-height:1.3;font-size:1.02rem}
.header-phones a{color:#222}
.header-phones a:hover{color:var(--red)}
.lang-switch{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;
  background:#fff;border:1px solid #bcbcbc;border-radius:8px;color:#222;font-weight:700;font-size:.85rem}
.lang-switch:hover{border-color:var(--red);color:var(--red);text-decoration:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:42px;height:38px;background:#fff;
  border:1px solid #bcbcbc;border-radius:8px;cursor:pointer;align-items:center;justify-content:center}
.nav-toggle span{width:20px;height:2px;background:var(--ink)}
.main-nav{background:#6e6e6e}
.main-nav ul{display:flex;flex-wrap:wrap;justify-content:center;list-style:none;margin:0;padding:0}
.main-nav a{display:block;color:#fff;padding:14px 18px;font-weight:600;text-transform:uppercase;
  font-size:.82rem;letter-spacing:.02em}
.main-nav a:hover{background:rgba(0,0,0,.18);text-decoration:none}
.main-nav .active a{background:var(--red)}

/* Hero */
.hero{background:var(--bg-soft);padding:22px 0}
.hero__grid{display:grid;grid-template-columns:1.4fr .9fr;gap:20px}
.hero__media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#000}
.hero__slider{position:relative;aspect-ratio:16/10}
.hero__slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity 1s}
.hero__slider img:first-child,.hero__slider img.is-active{opacity:1}
.hero__caption{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;color:#fff;
  background:linear-gradient(transparent,rgba(0,0,0,.78))}
.hero__caption h1{color:#fff;margin:0 0 6px;font-size:clamp(1.3rem,2.6vw,2rem)}
.hero__caption p{margin:0 0 12px;font-size:.98rem;max-width:36em}
.hero__cta{display:flex;gap:10px;flex-wrap:wrap}
.hero__cta .btn--ghost{color:#fff;border-color:rgba(255,255,255,.75)}
.hero__cta .btn--ghost:hover{background:rgba(255,255,255,.16);border-color:#fff;color:#fff}

/* Calculator */
.hero__calc{display:flex}
.calc{background:var(--red);color:#fff;border-radius:var(--radius);padding:18px;width:100%;
  box-shadow:var(--shadow)}
.calc__title{color:#fff;font-size:1.05rem;margin:0 0 14px;border-bottom:2px solid rgba(255,255,255,.4);
  padding-bottom:10px}
.calc__row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.calc__field{display:flex;flex-direction:column;gap:4px;font-size:.82rem}
.calc select,.calc input{padding:9px 10px;border:0;border-radius:7px;font-size:.92rem;background:#fff;color:var(--ink)}
.calc .btn--accent{background:#fff;color:var(--red);border-color:#fff;width:100%;margin-top:4px}
.calc .btn--accent:hover{background:#f2f2f2;color:var(--red-d)}
.calc__result{margin-top:12px;background:rgba(255,255,255,.16);border-radius:8px;padding:12px;font-size:1.05rem}
.calc__result b{font-size:1.3rem}
.calc__hint{font-size:.76rem;opacity:.85;margin:10px 0 0}

/* Hero order form (червона панель замість калькулятора) */
.hero__form{display:flex}
.order-form.order-form--hero{background:var(--red);color:#fff;width:100%;box-shadow:var(--shadow)}
.order-form.order-form--hero h3{color:#fff;border-bottom:2px solid rgba(255,255,255,.4);padding-bottom:10px}
.order-form.order-form--hero .btn--accent{background:#fff;color:var(--red);border-color:#fff}
.order-form.order-form--hero .btn--accent:hover{background:#f1f1f1;color:var(--red-d)}
.order-form.order-form--hero input,.order-form.order-form--hero textarea{border-color:transparent}
.order-form.order-form--hero .form-note{color:rgba(255,255,255,.82)}

/* Спливаюче вікно (заклик до дії) */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;
  padding:18px;background:rgba(0,0,0,.6)}
.modal.open{display:flex;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
body.modal-open{overflow:hidden}
.modal__box{position:relative;background:#fff;border-radius:14px;max-width:440px;width:100%;
  padding:26px 22px 20px;box-shadow:0 20px 60px rgba(0,0,0,.4);animation:pop .25s}
@keyframes pop{from{transform:translateY(14px);opacity:0}to{transform:none;opacity:1}}
.modal__close{position:absolute;top:8px;right:12px;background:none;border:0;font-size:30px;line-height:1;
  color:#999;cursor:pointer}
.modal__close:hover{color:var(--red)}
.modal__head{text-align:center;margin-bottom:14px}
.modal__head h3{margin:0 0 6px;color:var(--red)}
.modal__head p{margin:0;color:#555;font-size:.92rem}
.modal .order-form{padding:0;box-shadow:none}
.modal .order-form h3{display:none}
.modal__phones{text-align:center;margin-top:12px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.modal__phones a{font-weight:700;color:var(--ink)}

/* Sections */
.section{padding:42px 0}
.section--muted{background:var(--bg-soft)}
.section__title{text-align:center;margin-bottom:24px;position:relative}
.section__title::after{content:"";display:block;width:54px;height:3px;background:var(--red);margin:10px auto 0}

/* Fleet cards (strip) */
.fleet-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.bus-card{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);color:var(--ink)}
.bus-card:hover{text-decoration:none;transform:translateY(-3px);transition:.15s}
.bus-card__img{height:170px;background:#e9e9e9;overflow:hidden}
.bus-card__img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.bus-card__body{background:var(--red);color:#fff;padding:10px 12px;flex:1;display:flex;flex-direction:column;gap:4px}
.bus-card__title{font-weight:700;font-size:.92rem}
.bus-card__meta{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;gap:8px}
.bus-card__meta i{font-style:normal;opacity:.92}

/* Ticks / steps */
.ticks{list-style:none;padding:0;margin:0 0 1em}
.ticks li{position:relative;padding-left:28px;margin-bottom:8px}
.ticks li::before{content:"";position:absolute;left:0;top:7px;width:16px;height:9px;
  border-left:3px solid var(--red);border-bottom:3px solid var(--red);transform:rotate(-45deg)}
.ticks--2col{columns:2;column-gap:32px}
.steps{margin:0 0 1em;padding-left:1.2em}
.steps li{margin-bottom:8px}

/* Why grid */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.why-card h3{margin:0 0 6px;font-size:1.05rem;color:var(--red)}
.why-card p{margin:0;font-size:.92rem;color:#555}

/* Breadcrumbs */
.breadcrumbs{background:var(--bg-soft);font-size:.86rem;color:var(--muted);padding:10px 0;border-bottom:1px solid var(--line)}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs span{margin:0 4px}

/* Inline CTA in articles */
.inline-cta{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0}

/* FAQ */
.faq__title{margin-top:32px}
.faq__item{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;background:#fff}
.faq__item summary{cursor:pointer;padding:14px 16px;font-weight:600;list-style:none}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"+";float:right;color:var(--red);font-weight:700}
.faq__item[open] summary::after{content:"–"}
.faq__a{padding:0 16px 14px;color:#555}

/* Park grid */
.park-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.park-card{display:grid;grid-template-columns:180px 1fr;gap:14px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.park-card__media{height:190px;border-radius:8px;overflow:hidden;background:#e9e9e9}
.park-card__media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.park-card__title{margin:0 0 6px;font-size:1.15rem}
.park-card__spec{color:#666;font-size:.9rem;margin:0 0 10px}
.park-card__specs{list-style:none;padding:0;margin:0 0 12px;font-size:.9rem}
.park-card__specs li{display:flex;justify-content:space-between;border-bottom:1px dashed var(--line);padding:5px 0}
.park-card__specs span{color:#777}

/* Routes */
.routes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.route-card{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:12px 14px;color:var(--ink);transition:.15s}
.route-card:hover{text-decoration:none;border-color:var(--red);box-shadow:var(--shadow);transform:translateY(-2px)}
.route-card__path{font-weight:600}
.route-card__km{color:var(--muted);font-size:.86rem;margin-left:auto}
.route-card__btn{font-size:.82rem;font-weight:700;color:var(--red);white-space:nowrap}

/* Факты маршрута + плашка-уведомление */
.route-facts{display:flex;gap:14px;list-style:none;padding:0;margin:0 0 18px;flex-wrap:wrap}
.route-facts li{display:flex;flex-direction:column;background:var(--bg-soft);border-radius:8px;padding:10px 16px}
.route-facts span{color:#777;font-size:.82rem}
.route-facts b{font-size:1.15rem}
.notice{background:#fff7e6;border-left:4px solid #f0a500;border-radius:6px;padding:12px 16px;
  color:#7a5b00;font-size:.92rem;margin:18px 0}
.route-back{margin-top:22px}

/* Tariffs table */
.table-wrap{overflow-x:auto}
.tariffs{width:100%;border-collapse:collapse;background:#fff}
.tariffs th,.tariffs td{padding:12px 14px;border-bottom:1px solid var(--line);text-align:left}
.tariffs thead th{background:var(--grey);color:#fff;font-weight:600}
.tariffs tbody tr:nth-child(even){background:var(--bg-soft)}
.note{color:#777;font-size:.88rem;margin-top:14px}

/* Facts */
.facts{display:flex;gap:24px;list-style:none;padding:0;margin:26px 0 0;flex-wrap:wrap}
.facts li{display:flex;flex-direction:column}
.facts b{font-size:2rem;color:var(--red);line-height:1}
.facts span{color:#666;font-size:.9rem}

/* Contacts */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:24px;margin-top:10px}
.contact-list{list-style:none;padding:0;margin:0 0 18px}
.contact-list li{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding:10px 0}
.contact-list span{color:#777}
.contact-messengers{display:flex;gap:10px;flex-wrap:wrap}
.contact-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}

/* CTA */
.cta{background:var(--grey);color:#fff;padding:36px 0}
.cta__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center}
.cta__text h2{color:#fff}
.cta__text p{color:rgba(255,255,255,.88)}
.cta__phones{display:flex;gap:18px;flex-wrap:wrap;margin-top:12px}
.cta__phone{color:#fff;font-size:1.25rem;font-weight:700}
.order-form{background:#fff;border-radius:14px;padding:24px;box-shadow:var(--shadow)}
.order-form h3{margin:0 0 16px;color:var(--ink);font-size:1.25rem}
.order-form input,.order-form textarea{width:100%;padding:13px 14px;border:1.5px solid #e1e4e8;
  border-radius:10px;margin-bottom:12px;font-size:1rem;font-family:inherit;background-color:#fafbfc;
  color:var(--ink);transition:border-color .15s,box-shadow .15s,background-color .15s}
.order-form input::placeholder,.order-form textarea::placeholder{color:#9aa0a6}
.order-form input:focus,.order-form textarea:focus{outline:none;border-color:var(--red);background-color:#fff;
  box-shadow:0 0 0 3px rgba(203,1,6,.12)}
.order-form textarea{resize:vertical;min-height:88px}
/* иконки в полях имя/телефон */
.order-form input[name=name]{padding-left:42px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239aa0a6'%3E%3Cpath d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10zm0 2c-5 0-9 2.5-9 6v2h18v-2c0-3.5-4-6-9-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:13px center;background-size:18px}
.order-form input[name=phone]{padding-left:42px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%239aa0a6'%3E%3Cpath d='M6.6 10.8a15.5 15.5 0 0 0 6.6 6.6l2.2-2.2c.3-.3.7-.4 1-.2 1.1.4 2.3.6 3.5.6.6 0 1 .4 1 1V20c0 .6-.4 1-1 1A17 17 0 0 1 3 4c0-.6.4-1 1-1h3.4c.6 0 1 .4 1 1 0 1.2.2 2.4.6 3.5.1.4 0 .8-.2 1l-2.2 2.3z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:13px center;background-size:18px}
.order-form .hp{display:none}
.order-form .btn{width:100%;padding:14px;font-size:1.02rem;margin-top:2px}
.order-form .form-note{font-size:.76rem;color:#9aa0a6;text-align:center;margin:12px 0 0;line-height:1.4}
.order-form__msg{margin-top:12px;padding:11px 12px;border-radius:8px;font-size:.9rem}
.order-form__msg.ok{background:#e6f6e9;color:#177a2e}
.order-form__msg.err{background:#fde8e8;color:#a8131a}

/* Footer */
.site-footer{background:#2b2b2b;color:#cfcfcf;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:24px;padding:36px 16px}
.footer-col h3{color:#fff;font-size:1rem;margin:0 0 12px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:7px}
.footer-col a{color:#cfcfcf;font-size:.92rem}
.footer-col a:hover{color:#fff}
.logo--footer img{width:180px;margin-bottom:12px;filter:brightness(0) invert(1) opacity(.9)}
.footer-about p{font-size:.9rem;color:#a8a8a8}
.footer-contacts li{font-size:.92rem}
.footer-bottom{border-top:1px solid #3d3d3d;padding:14px 0;font-size:.82rem;color:#9a9a9a}
.footer-bottom .container{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* Floating call */
.float-call{position:fixed;right:18px;bottom:18px;width:56px;height:56px;border-radius:50%;
  background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(203,1,6,.45);z-index:50;animation:pulse 2.4s infinite}
.float-call:hover{background:var(--red-d)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(203,1,6,.5)}70%{box-shadow:0 0 0 14px rgba(203,1,6,0)}100%{box-shadow:0 0 0 0 rgba(203,1,6,0)}}

/* ---- Responsive ---- */
@media (max-width:980px){
  .hero__grid{grid-template-columns:1fr}
  .fleet-cards{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .park-grid{grid-template-columns:1fr}
  .routes-grid{grid-template-columns:repeat(2,1fr)}
  .cta__inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .header-phones{display:none}
  .nav-toggle{display:flex}
  .main-nav{position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;transform:translateX(100%);
    transition:transform .25s;z-index:60;background:var(--grey);padding-top:60px;overflow:auto}
  .main-nav.open{transform:none}
  .main-nav ul{flex-direction:column}
  .main-nav a{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.1)}
  body.nav-open{overflow:hidden}
  body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55}
  .ticks--2col{columns:1}
  .fleet-cards{grid-template-columns:repeat(2,1fr)}
  .routes-grid{grid-template-columns:1fr}
  .park-card{grid-template-columns:1fr}
  .park-card__media img{aspect-ratio:3/2}
  /* таблица тарифов -> карточки */
  .tariffs thead{display:none}
  .tariffs,.tariffs tbody,.tariffs tr,.tariffs td{display:block;width:100%}
  .tariffs tr{margin-bottom:12px;border:1px solid var(--line);border-radius:8px}
  .tariffs td{display:flex;justify-content:space-between;border:none;border-bottom:1px solid var(--line)}
  .tariffs td::before{content:attr(data-l);color:#777;font-weight:600}
}
@media (max-width:420px){
  .fleet-cards{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr}
  .calc__row{grid-template-columns:1fr}
}
