
    :root {
      --primary: #e8840ab6;
      --primary-dark: #c0340a;
      --dark2: #1a1a1a;
      --dark3: #242424;
      --light: #f5f2ee;
      --muted: #888;
      --border: rgba(255,255,255,0.08);
    }

    * { box-sizing: border-box; }

    body {
      font-family: 'Outfit', sans-serif;
      background: var(--dark);
      color: var(--light);
      overflow-x: hidden;
    }

    h1, h2, h3, h4 {
      font-family: 'Syne', sans-serif;
    }

    /* ── NAVBAR ── */
    .navbar {
      background: rgba(15,15,15,0.96) !important;
      backdrop-filter: blur(12px);
      border-bottom: 1px solid var(--border);
      
    }
    .navbar-brand {
      font-family: 'Syne', sans-serif;
      font-size: 1.2rem;
      font-weight: 700;
      color: var(--light) !important;
      margin: 0px;
      padding: 0px;
    
    }
    .navbar-brand span { color: var(--primary); }
    .nav-link {
      color: var(--muted) !important;
      font-size: 0.85rem;
      letter-spacing: 0.05em;
      text-transform: uppercase;
      transition: color 0.2s;
    }
    .nav-link:hover { color: var(--light) !important; }
    .navbar-toggler { border-color: var(--border); }
    .navbar-toggler-icon {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(245,242,238,0.75)' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
    }
    .btn-nav {
      background: var(--primary);
      color: #fff !important;
      padding: 8px 20px !important;
      border-radius: 4px;
      font-weight: 600 !important;
      transition: background 0.2s !important;
    }
    .btn-nav:hover { background: var(--primary-dark) !important; color: #fff !important; }

    /* ── HERO ── */
    .hero {
      min-height: 100vh;
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: center;
      padding-top: 76px;
    
    }
    .hero-grid {
      position: absolute;
      inset: 0;
      background-image:
        linear-gradient(rgba(232,65,10,0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(232,65,10,0.035) 1px, transparent 1px);
      background-size: 48px 48px;
      pointer-events: none;
    }
    .hero-glow {
      position: absolute;
      width: 700px; height: 700px;
      background: radial-gradient(circle, rgba(232,65,10,0.1) 0%, transparent 70%);
      top: 50%; right: -100px;
      transform: translateY(-50%);
      pointer-events: none;
    }
    .hero-badge {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: rgba(232,65,10,0.1);
      border: 1px solid rgba(232,65,10,0.25);
      color: var(--primary);
      font-size: 0.75rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      padding: 6px 14px;
      border-radius: 100px;
      margin-bottom: 24px;
    }
    .hero-title {
      font-size: 40px;
      font-weight: 800;
      line-height: 0.95;
      letter-spacing: -0.03em;
      margin-bottom: 24px;
      color: var(--light);
    }
    .hero-title .accent { color: var(--primary); }
    .hero-subtitle {
      color: var(--muted);
      font-size: 1.05rem;
      font-weight: 300;
      line-height: 1.7;
      max-width: 460px;
      margin-bottom: 36px;
    }
    .btn-hero-primary {
      background: var(--primary);
      color: #fff;
      border: none;
      padding: 14px 30px;
      font-family: 'Outfit', sans-serif;
      font-weight: 600;
      font-size: 0.95rem;
      border-radius: 5px;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      transition: background 0.2s, transform 0.2s;
    }
    .btn-hero-primary:hover { background: var(--primary-dark); color: #fff; transform: translateY(-2px); }
    .btn-hero-ghost {
      background: transparent;
      color: var(--light);
      border: 1px solid var(--border);
      padding: 14px 30px;
      font-family: 'Outfit', sans-serif;
      font-size: 0.95rem;
      border-radius: 5px;
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      transition: border-color 0.2s, color 0.2s;
    }
    .btn-hero-ghost:hover { border-color: var(--primary); color: var(--primary); }
    .hero-stats-row {
      border-top: 1px solid var(--border);
      margin-top: 44px;
      padding-top: 32px;
    }
    .stat-num {
      font-family: 'Syne', sans-serif;
      font-size: 2.4rem;
      font-weight: 800;
      color: var(--primary);
      line-height: 1;
    }
    .stat-lbl {
      font-size: 0.72rem;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: var(--muted);
      margin-top: 4px;
    }

    /* Hero bus card */
    .bus-card {
      background: var(--dark2);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 30px;
      position: relative;
      overflow: hidden;
      height: 350px;
    }
    .bus-card::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 3px;
      background: var(--primary);
    }
    .bus-route-watermark {
      position: absolute;
      top: 16px; right: 20px;
      font-family: 'Syne', sans-serif;
      font-size: 5rem;
      font-weight: 800;
      color: rgba(232,65,10,0.07);
      line-height: 1;
      pointer-events: none;
    }
    .live-dot {
      width: 8px; height: 8px;
      background: #22c55e;
      border-radius: 50%;
      display: inline-block;
      animation: pulse-dot 1.5s ease infinite;
    }
    @keyframes pulse-dot {
      0%,100% { box-shadow: 0 0 0 0 rgba(34,197,94,0.4); }
      50% { box-shadow: 0 0 0 6px rgba(34,197,94,0); }
    }
    .mini-stat-box {
      background: var(--dark3);
      border-radius: 8px;
      padding: 14px;
      text-align: center;
    }
    .mini-stat-num {
      font-family: 'Syne', sans-serif;
      font-size: 1.3rem;
      font-weight: 800;
      color: var(--primary);
    }
    .mini-stat-lbl {
      font-size: 0.68rem;
      color: var(--muted);
      text-transform: uppercase;
      letter-spacing: 0.08em;
    }
    .progress-track {
      height: 6px;
      background: var(--dark);
      border-radius: 3px;
      margin-top: 10px;
      overflow: hidden;
    }
    .progress-fill {
      height: 100%;
      width: 65%;
      background: var(--primary);
      border-radius: 3px;
      animation: prog 3s ease-in-out infinite alternate;
    }
    @keyframes prog { from { width:55%; } to { width:75%; } }

    /* ── TICKER ── */
    .ticker-wrap {
      background: var(--primary);
      padding: 12px 0;
      overflow: hidden;
      white-space: nowrap;
    }
    .ticker-track {
      display: inline-block;
      animation: ticker 26s linear infinite;
      font-family: 'Syne', sans-serif;
      font-size: 0.88rem;
      font-weight: 700;
      letter-spacing: 0.1em;
      color: #fff;
    }
    .ticker-track .sep { opacity: 0.5; margin: 0 28px; }
    @keyframes ticker {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    /* ── SECTION LABELS ── */
    .sec-label {
      font-size: 0.72rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
      color: var(--primary);
      margin-bottom: 10px;
    }
    .sec-title {
      font-family: 'Syne', sans-serif;
      font-size: clamp(2rem, 4vw, 3.4rem);
      font-weight: 800;
      letter-spacing: -0.02em;
      line-height: 1.05;
    }

    /* ── ROUTE FINDER ── */
    .finder-section { background: var(--dark); padding: 100px 0;}
    .finder-box {
      background: var(--dark2);
      border: 1px solid var(--border);
      border-radius: 12px;
      padding: 36px;
      margin-top: 44px;
    }
    .field-lbl {
      font-size: 0.7rem;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--muted);
      display: block;
      margin-bottom: 8px;
    }
    .field-input {
      background: var(--dark3);
      border: 1px solid rgba(255,255,255,0.07);
      color: var(--light);
      padding: 12px 15px;
      border-radius: 6px;
      font-family: 'Outfit', sans-serif;
      font-size: 0.93rem;
      width: 100%;
      outline: none;
      transition: border-color 0.2s;
    }
    .field-input:focus { border-color: var(--primary); }
    .field-input::placeholder { color: var(--muted); }
    .btn-search {
      background: var(--primary);
      color: #fff;
      border: none;
      width: 100%;
      padding: 12px;
      border-radius: 6px;
      font-family: 'Outfit', sans-serif;
      font-weight: 600;
      font-size: 0.93rem;
      transition: background 0.2s;
      cursor: pointer;
    }
    .btn-search:hover { background: var(--primary-dark); }

    /* ── ROUTE CARDS ── */
    .route-card {
      background: var(--dark2);
      border: 1px solid var(--border);
      border-radius: 12px;
      padding: 26px;
      height: 100%;
      position: relative;
      overflow: hidden;
      transition: transform 0.25s, border-color 0.25s;
    }
    .route-card:hover { transform: translateY(-4px); border-color: rgba(232,65,10,0.4); }
    .route-card::after {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 3px;
      background: var(--primary);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform 0.3s;
    }
    .route-card:hover::after { transform: scaleX(1); }
    .route-num-bg {
      position: absolute;
      top: 12px; right: 16px;
      font-family: 'Syne', sans-serif;
      font-size: 4rem;
      font-weight: 800;
      color: rgba(232,65,10,0.07);
      line-height: 1;
    }
    .route-pill {
      background: rgba(232,65,10,0.12);
      color: var(--primary);
      font-size: 0.7rem;
      font-weight: 600;
      letter-spacing: 0.1em;
      padding: 3px 10px;
      border-radius: 4px;
      display: inline-block;
      margin-bottom: 12px;
    }
    .route-name {
      font-family: 'Syne', sans-serif;
      font-size: 1.15rem;
      font-weight: 700;
      margin-bottom: 6px;
      line-height: 1.3;
    }
    .route-via { color: var(--muted); font-size: 0.82rem; margin-bottom: 18px; }
    .route-meta {
      border-top: 1px solid var(--border);
      padding-top: 14px;
      display: flex;
      gap: 18px;
    }
    .route-meta-item strong { display: block; font-size: 0.88rem; }
    .route-meta-item span { font-size: 0.68rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }

    
    /* ── FEATURES ── */
    .features-section { background: var(--dark); padding: 100px 0; }
    .feat-card {
      background: var(--dark2);
      border: 1px solid var(--border);
      border-radius: 12px;
      padding: 30px 26px;
      height: 100%;
      transition: transform 0.25s, border-color 0.25s;
    }
    .feat-card:hover { transform: translateY(-4px); border-color: rgba(232,65,10,0.3); }
    .feat-icon {
      width: 50px; height: 50px;
      background: rgba(232,65,10,0.1);
      border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.3rem;
      color: var(--primary);
      margin-bottom: 18px;
    }



.section {
    padding: 50px;

    color: rgba(5, 4, 0, 0.918);
}

.section-title {
    text-align: center;
    margin-bottom: 30px;
}

    .feat-title { font-family: 'Syne', sans-serif; font-size: 1.05rem; font-weight: 700; margin-bottom: 10px; }
    .feat-desc { color: var(--muted); font-size: 0.88rem; line-height: 1.65; }

    /* ── FOOTER ── */
    footer { background: var(--dark2); border-top: 1px solid var(--border); padding: 60px 0 28px; }
    .footer-brand { font-family: 'Syne', sans-serif; font-size: 1.5rem; font-weight: 800; color: var(--light); margin-bottom: 12px; }
    .footer-brand span { color: var(--primary); }
    .footer-text { color: var(--muted); font-size: 0.87rem; line-height: 1.7; }
    .footer-heading { font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--primary); margin-bottom: 14px; }
    .footer-list { list-style: none; padding: 0; }
    .footer-list li { margin-bottom: 10px; }
    .footer-list a { color: var(--muted); text-decoration: none; font-size: 0.87rem; transition: color 0.2s; }
    .footer-list a:hover { color: var(--light); }
    .footer-bottom { border-top: 1px solid var(--border); padding-top: 22px; margin-top: 44px; color: var(--muted); font-size: 0.78rem; }
    .social-link { color: var(--muted); font-size: 1.25rem; text-decoration: none; transition: color 0.2s; }
    .social-link:hover { color: var(--primary); }

    /* ── JOURNEY SECTION ── */
    .journey-section {
      background: rgba(183, 135, 13, 0.76);
      padding: 80px 0;
      
    }
    .journey-section h2 {
      font-family: 'Syne', sans-serif;
      font-size: clamp(1.8rem, 3.5vw, 2.8rem);
      font-weight: 800;
      color: var(--light);
      text-align: center;
      margin-bottom: 10px;
    }
    .journey-section .sec-label {
      text-align: center;
      display: block;
      margin-bottom: 8px;
    }
    .journey-cards-grid {
      display: flex;
      flex-direction: column;
      gap: 20px;
      margin-top: 40px;
    }
    .journey-card {
      background: var(--dark2);
      border: 1px solid var(--border);
      border-radius: 14px;
      display: flex;
      align-items: stretch;
      overflow: hidden;
      transition: transform 0.25s, border-color 0.25s;
      position: relative;
    }
    .journey-card::before {
      content: '';
      position: absolute;
      left: 0; top: 0; bottom: 0;
      width: 4px;
      background: var(--primary);
      border-radius: 4px 0 0 4px;
    }
    .journey-card:hover {
      transform: translateY(-3px);
      border-color: rgba(232,132,10,0.4);
    }
    .journey-card-img {
      width: 180px;
      min-height: 130px;
      object-fit: cover;
      flex-shrink: 0;
    }
    .journey-card-body {
      padding: 20px 24px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      flex: 1;
    }
    .journey-card-body h4 {
      font-family: 'Syne', sans-serif;
      font-size: 1.1rem;
      font-weight: 700;
      color: var(--light);
      margin-bottom: 6px;
    }
    .journey-card-body p {
      color: var(--muted);
      font-size: 0.88rem;
      margin-bottom: 10px;
    }
    .journey-card-body .price {
      font-family: 'Syne', sans-serif;
      font-size: 1.3rem;
      font-weight: 800;
      color: var(--primary);
    }
    .journey-card-actions {
      padding: 20px 24px;
      display: flex;
      align-items: center;
      justify-content: flex-end;
      flex-shrink: 0;
    }
    .btn-book {
      background: var(--primary);
      color: #fff;
      border: none;
      padding: 10px 22px;
      border-radius: 6px;
      font-family: 'Outfit', sans-serif;
      font-weight: 600;
      font-size: 0.88rem;
      cursor: pointer;
      transition: background 0.2s, transform 0.2s;
      white-space: nowrap;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .btn-book:hover {
      background: var(--primary-dark);
      transform: translateY(-1px);
    }
    .journey-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }
    @media (max-width: 768px) {
      .journey-row { grid-template-columns: 1fr; }
      .journey-card-img { width: 120px; min-height: 110px; }
      .journey-card-actions { padding: 16px; }
    }

    /* Scroll reveal */
    .reveal { opacity: 0; transform: translateY(22px); transition: opacity 0.6s ease, transform 0.6s ease; }
    .reveal.visible { opacity: 1; transform: none; }
