/* ===================== PAGE FATHER STYLE ===================== */
:root{
  --red:#E8411E;--red-d:#C1320F;--red-l:#FEF0EB;
  --ink:#0D1117;--ink2:#1C2532;
  --grey1:#F4F5F7;--grey2:#E8EAED;--grey3:#BFC5CE;--grey4:#7B8694;--grey5:#3D4A5C;
  --white:#FFFFFF;
  --green:#12B76A;--amber:#F59E0B;--blue:#3B82F6;
  --r:14px;--r-sm:8px;--r-xs:6px;
  --sh1:0 1px 4px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh2:0 4px 20px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.05);
  --sh3:0 12px 48px rgba(0,0,0,.13);
  --f-head:'Syne',sans-serif;
  --f-body:'Instrument Sans',sans-serif;
  --tr:all .22s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--f-body);background:var(--grey1);color:var(--ink);min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:var(--f-body)}
input,select,textarea{font-family:var(--f-body)}

/* ===================== PAGE SYSTEM ===================== */
.page{display:none;animation:fadeUp .35s ease both}
.page.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ===================== NAVBAR ===================== */
.navbar-app{
  background:var(--white);
  border-bottom:1px solid var(--grey2);
  padding:0;
  position:sticky;top:0;z-index:1000;
}
.navbar-inner{
  max-width:1200px;margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:62px;
}
.brand{
  font-family:var(--f-head);font-size:22px;font-weight:800;
  display:flex;align-items:center;gap:6px;cursor:pointer;
}
.brand-icon{
  width:32px;height:32px;background:var(--red);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:16px;
}
.brand-text{color:var(--ink)}
.brand-text span{color:var(--red)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link-item{
  padding:7px 14px;border-radius:var(--r-sm);font-size:14px;font-weight:500;
  color:var(--grey4);cursor:pointer;transition:var(--tr);
}
.nav-link-item:hover{color:var(--ink);background:var(--grey1)}
.nav-link-item.active-nav{color:var(--red);background:var(--red-l)}
.btn-nav-cta{
  background:var(--red);color:#fff;padding:8px 18px;border-radius:var(--r-sm);
  font-size:14px;font-weight:600;cursor:pointer;border:none;
  transition:var(--tr);margin-left:8px;
}
.btn-nav-cta:hover{background:var(--red-d);box-shadow:0 4px 14px rgba(232,65,30,.3)}
.hamburger{display:none;background:none;border:none;font-size:20px;color:var(--ink);cursor:pointer}
.mobile-menu{display:none;background:var(--white);border-top:1px solid var(--grey2);padding:12px 24px 16px}
.mobile-menu.open{display:block}
.mobile-nav-item{
  padding:11px 0;border-bottom:1px solid var(--grey2);font-size:15px;
  color:var(--grey5);cursor:pointer;display:flex;align-items:center;gap:10px;
}
.mobile-nav-item:last-child{border-bottom:none}
.mobile-nav-item i{width:18px;color:var(--red)}

/* Home page styles are moved to home.css */
/* Results page styles are moved to results.css */

/* Page-specific styles have been moved into dedicated page CSS files. */
/* Results page styles are moved to results.css */

/* ===================== PAGE 3: CEK TIKET ===================== */
/* Ticket page styles are moved to cek.css */

/* ===================== PAGE 4: REGISTER ===================== */
.auth-page{max-width:460px;margin:0 auto;padding:40px 24px}
.auth-card{background:var(--white);border:1px solid var(--grey2);border-radius:var(--r);padding:32px;box-shadow:var(--sh1)}
.auth-logo{text-align:center;margin-bottom:24px}
.auth-title{font-family:var(--f-head);font-size:24px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:6px}
.auth-sub{font-size:14px;color:var(--grey4);text-align:center;margin-bottom:28px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.input-icon-wrapper{position:relative}
.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--grey3);font-size:14px}
/* Toast */
.toast-app{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:#fff;padding:12px 20px;border-radius:40px;
  font-size:14px;font-weight:500;z-index:9999;
  opacity:0;transition:var(--tr);pointer-events:none;
  display:flex;align-items:center;gap:8px;white-space:nowrap;
}
.toast-app.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===================== FOOTER ===================== */
.footer{background:var(--ink);color:rgba(255,255,255,.5);padding:40px 24px 24px;font-size:13px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
.footer-brand{font-family:var(--f-head);font-size:20px;font-weight:800;color:#fff;margin-bottom:8px}
.footer-desc{line-height:1.7;margin-bottom:16px}
.footer-social{display:flex;gap:10px}
.social-btn{
  width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);
  font-size:14px;cursor:pointer;transition:var(--tr);
}
.social-btn:hover{background:var(--red);color:#fff}
.footer-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(255,255,255,.8);margin-bottom:14px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-links li{cursor:pointer;transition:var(--tr)}
.footer-links li:hover{color:rgba(255,255,255,.9)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* ===================== RESPONSIVE ===================== */
@media(max-width:991px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:767px){
  .nav-links,.btn-nav-cta{display:none}
  .hamburger{display:block}
  .footer-grid{grid-template-columns:1fr}
}

/* ===================== PAGE FATHER STYLE END ===================== */

/* ===================== PAGE HOME STYLE ===================== */
/* Home-only page styles */
.hero{
  background:linear-gradient(135deg,#0D1117 0%,#1C2532 60%,#2D1A0E 100%);
  padding:72px 24px 120px;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero-decoration{
  position:absolute;right:-80px;top:-80px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(232,65,30,.2) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero-decoration2{
  position:absolute;left:-100px;bottom:-100px;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(59,130,246,.12) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero-content{max-width:780px;margin:0 auto;text-align:center;position:relative;z-index:1}
.hero-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.8);font-size:12px;font-weight:500;
  padding:5px 14px;border-radius:20px;margin-bottom:24px;backdrop-filter:blur(4px);
}
.hero-badge i{color:var(--amber)}
.hero-title{
  font-family:var(--f-head);font-size:clamp(32px,6vw,58px);font-weight:800;
  color:#fff;line-height:1.1;margin-bottom:16px;
  letter-spacing:-.5px;
}
.hero-title span{
  color:transparent;-webkit-text-stroke:2px var(--red);
}
.hero-sub{font-size:16px;color:rgba(255,255,255,.55);margin-bottom:40px;line-height:1.7}
.hero-actions{
  display:flex;align-items:center;justify-content:center;gap:12px;
  flex-wrap:wrap;margin:0 0 28px;
}
.hero-btn-primary,.hero-btn-secondary{
  display:inline-flex;align-items:center;gap:8px;border-radius:999px;
  padding:11px 18px;font-size:14px;font-weight:700;transition:var(--tr);
}
.hero-btn-primary{
  background:var(--red);color:#fff;border:1px solid var(--red);
  box-shadow:0 8px 22px rgba(232,65,30,.25);
}
.hero-btn-primary:hover{background:var(--red-d);border-color:var(--red-d);transform:translateY(-1px)}
.hero-btn-secondary{
  background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.22);
}
.hero-btn-secondary:hover{background:rgba(255,255,255,.12);transform:translateY(-1px)}

.search-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  padding:28px;box-shadow:var(--sh3);
  position:relative;z-index:2;
  backdrop-filter:blur(4px);
}
.search-tabs{display:flex;gap:4px;margin-bottom:24px;
  /* background:var(--grey1); */
  padding:4px;border-radius:var(--r-sm)}
.search-tab{
  flex:1;text-align:center;padding:9px;border-radius:6px;font-size:13px;font-weight:600;
  /* color:var(--grey4); */
  cursor:pointer;transition:var(--tr);
}
.search-tab.active{background:var(--white);color:var(--ink);box-shadow:var(--sh1)}
.form-row-search{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto;gap:0;align-items:stretch;}
.search-field{
  display:flex;flex-direction:column;padding:12px 16px;
  border:1.5px solid var(--grey2);border-right:none;
  border-radius:var(--r-sm) 0 0 var(--r-sm);
  cursor:pointer;transition:var(--tr);background:var(--white);
  min-width:0;
}
.search-field:nth-child(3){border-radius:0;border-right:none}
.search-field:nth-child(5){border-radius:0 var(--r-sm) var(--r-sm) 0;border-right:1.5px solid var(--grey2)}
.search-field:focus-within{border-color:var(--red);z-index:1}
.field-label{font-size:11px;font-weight:600;color:var(--grey4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.field-input{
  border:none;outline:none;font-size:16px;font-weight:600;
  color:var(--ink);background:transparent;padding:0;width:100%;
}
.field-input::placeholder{color:var(--grey3);font-weight:400}
.field-input[type=date]::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer}
.swap-btn{
  width:44px;background:var(--grey1);border:1.5px solid var(--grey2);border-left:none;border-right:none;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  color:var(--grey4);transition:var(--tr);flex-shrink:0;
}
.swap-btn:hover{color:var(--red);background:var(--red-l)}
.search-submit{
  background:var(--red);color:#fff;border:none;border-radius:0 var(--r-sm) var(--r-sm) 0;
  padding:0 28px;font-family:var(--f-head);font-size:16px;font-weight:700;
  cursor:pointer;transition:var(--tr);display:flex;align-items:center;gap:8px;flex-shrink:0;
}
.search-submit:hover{background:var(--red-d);box-shadow:0 6px 20px rgba(232,65,30,.35)}

.popular-section{max-width:1200px;margin:0 auto;padding:60px 24px}
.section-label{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;
  color:var(--red);margin-bottom:8px;
}
.section-sublabel{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px;
  color:var(--red);margin-bottom:8px;
}
.section-title{font-family:var(--f-head);font-size:26px;font-weight:800;color:var(--ink);margin-bottom:24px}
.route-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}
.route-card{
  background:var(--white);border:1.5px solid var(--grey2);border-radius:var(--r);
  padding:18px;cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;
}
.route-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--red);transform:scaleY(0);transition:var(--tr);transform-origin:bottom;
}
.route-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--sh2)}
.route-card:hover::before{transform:scaleY(1)}
.rc-from{font-size:13px;color:var(--grey4);margin-bottom:2px}
.rc-cities{font-family:var(--f-head);font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px}
.rc-cities span{color:var(--grey3);font-weight:400;margin:0 4px}
.rc-price{font-size:13px;font-weight:600;color:var(--red)}
.rc-count{font-size:12px;color:var(--grey4);margin-top:2px}

.why-section{background:var(--ink2);padding:60px 24px}
.why-inner{max-width:1200px;margin:0 auto}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.why-card{text-align:center;padding:24px 16px}
.why-icon{
  width:56px;height:56px;background:rgba(232,65,30,.15);border-radius:12px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  font-size:24px;color:var(--red);
}
.why-title{font-family:var(--f-head);font-size:15px;font-weight:700;color:#fff;margin-bottom:6px}
.why-desc{font-size:13px;color:rgba(255,255,255,.45);line-height:1.6}

@media(max-width:991px){
  .form-row-search{grid-template-columns:1fr auto 1fr}
  .form-row-search .search-field:nth-child(5){display:none}
  .search-submit{border-radius:var(--r-sm);margin-top:10px;padding:12px 20px;width:100%}
  .why-grid{grid-template-columns:1fr 1fr}
  .results-grid{grid-template-columns:1fr}
  .filter-sidebar{display:none;position:fixed;inset:0;z-index:999;overflow-y:auto;border-radius:0;top:62px}
  .filter-sidebar.mobile-open{display:block}
  .mobile-filter-btn{display:flex}
  .footer-grid{grid-template-columns:1fr 1fr}
  .login-split{grid-template-columns:1fr}
  .login-left{display:none}
  .login-right{padding:32px 20px}
}
@media(max-width:767px){
  .nav-links,.btn-nav-cta{display:none}
  .hamburger{display:block}
  .hero{padding:48px 20px 90px}
  .form-row-search{grid-template-columns:1fr}
  .swap-btn{display:none}
  .search-field{border-radius:var(--r-sm)!important;border:1.5px solid var(--grey2)!important;margin-bottom:8px}
  .search-submit{border-radius:var(--r-sm)!important;margin-top:4px}
  .bus-card-top{grid-template-columns:1fr 1fr;gap:12px}
  .btn-select-bus{grid-column:1/-1}
  .trip-arrow{display:none}
  .footer-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .form-row-2{grid-template-columns:1fr}
  .ticket-details{grid-template-columns:1fr}
}

/* Terminal cards (replacing table) */
.terminal-cards {
  display: grid;
  /* Menggunakan 1fr 1fr untuk memastikan selalu 2 kolom di layar kecil */
  grid-template-columns: repeat(2, 1fr); 
  gap: 12px; /* Jarak sedikit diperkecil agar pas di layar kecil */
}
.terminal-card {
  background: var(--white);
  border: 1px solid var(--grey2);
  border-radius: var(--r);
  padding: 15px 10px; /* Padding dikurangi sedikit */
  text-align: center;
  transition: var(--tr);
  cursor: pointer;
} 
.terminal-card:hover{transform:translateY(-2px);box-shadow:var(--sh2);border-color:var(--red)}
.terminal-icon{
  width:48px;height:48px;background:var(--red-l);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto 12px;
  color:var(--red);font-size:18px;
}
.terminal-city{font-family:var(--f-head);font-size:16px;font-weight:700;color:var(--ink);margin-bottom:4px}
.terminal-address{font-size:13px;color:var(--grey4);line-height:1.5}

@media (min-width: 768px) {
  .terminal-cards {
    /* Kembali ke sistem otomatis kamu sebelumnya untuk layar lebar */
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 16px;
  }
}

/* Booking steps section */
.booking-section{max-width:1200px;margin:0 auto;padding:60px 24px;background:var(--grey1)}
.booking-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.booking-step{
  background:var(--white);border-radius:var(--r);padding:32px 24px;text-align:center;
  box-shadow:var(--sh1);position:relative;border:2px solid transparent;
}
.booking-step:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:var(--sh2)}
.step-number{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  width:32px;height:32px;background:var(--red);color:#fff;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;
}
.step-icon{
  width:64px;height:64px;background:linear-gradient(135deg,var(--red),var(--red-d));
  border-radius:16px;display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;color:#fff;font-size:24px;
}
.step-title{font-family:var(--f-head);font-size:18px;font-weight:700;color:var(--ink);margin-bottom:8px}
.step-desc{font-size:14px;color:var(--grey4);line-height:1.6}

@media(max-width:991px){
  .booking-steps{grid-template-columns:1fr}
  .terminal-cards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
}
@media(max-width:767px){
  .terminal-cards{grid-template-columns:1fr}
  .booking-steps{grid-template-columns:1fr}
}

/* ===================== PAGE HOME STYLE END ===================== */

/* ===================== PAGE LOGIN STYLE ===================== */
/* Auth and login/register shared styles */
.auth-page{min-height:calc(100vh - 62px);display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--grey1)}
.auth-card{background:var(--white);border:1px solid var(--grey2);border-radius:var(--r);padding:32px;box-shadow:var(--sh1);max-width:520px;width:100%}
.auth-logo{text-align:center;margin-bottom:22px}
.auth-title{font-family:var(--f-head);font-size:26px;font-weight:800;color:var(--ink);text-align:center;margin-bottom:10px}
.auth-sub{font-size:14px;color:var(--grey4);text-align:center;margin-bottom:30px;line-height:1.7}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-group{margin-bottom:18px}
.form-label{display:block;margin-bottom:8px;font-size:13px;color:var(--grey4);font-weight:600}
.input-app{width:100%;min-height:48px;border:1px solid var(--grey2);border-radius:var(--r-sm);padding:14px 16px;font-size:15px;color:var(--ink);background:var(--white);transition:var(--tr)}
.input-app:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 4px rgba(232,65,30,.1)}
.input-app::placeholder{color:var(--grey3)}
.input-icon-wrapper{position:relative}
.input-icon-wrapper .input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--grey3);font-size:14px;pointer-events:none}
.input-app.with-icon{padding-left:44px}
.pw-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--grey3);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;padding:6px}
.pw-toggle:hover{color:var(--ink)}
.strength-bar{height:4px;background:var(--grey2);border-radius:999px;margin-top:8px;overflow:hidden}
.strength-fill{height:100%;border-radius:999px;transition:var(--tr);width:0}
.strength-fill.weak{background:#EF4444;width:25%}
.strength-fill.medium{background:var(--amber);width:60%}
.strength-fill.strong{background:var(--green);width:100%}
.terms-check{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;font-size:13px;color:var(--grey4)}
.terms-check input{accent-color:var(--red);margin-top:3px;flex-shrink:0}
.terms-check a{color:var(--red);text-decoration:underline;cursor:pointer}
.auth-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--grey4)}
.auth-footer a{color:var(--red);font-weight:600;cursor:pointer}
.btn-primary.btn-block{width:100%;padding:14px 16px;border-radius:var(--r-sm);font-size:15px}

.login-split{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 62px)}
.login-left{background:linear-gradient(150deg,var(--ink) 0%,var(--ink2) 50%,#2D1A0E 100%);padding:48px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.login-left::before{content:'';position:absolute;right:-60px;bottom:-60px;width:360px;height:360px;background:radial-gradient(circle,rgba(232,65,30,.25) 0%,transparent 70%);border-radius:50%}
.login-illo{position:relative;z-index:1}
.login-illo-icon{width:80px;height:80px;background:rgba(232,65,30,.15);border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--red);margin-bottom:28px}
.login-left-title{font-family:var(--f-head);font-size:30px;font-weight:800;color:#fff;margin-bottom:14px;line-height:1.2}
.login-left-desc{font-size:15px;color:rgba(255,255,255,.75);line-height:1.8;margin-bottom:32px}
.feature-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.feature-list li{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.85)}
.feature-list li i{color:var(--green);width:20px}
.login-right{background:var(--white);display:flex;align-items:center;justify-content:center;padding:40px}
.login-form-wrap{width:100%;max-width:420px}

@media(max-width:991px){
  .login-split{grid-template-columns:1fr}
  .login-left{display:none}
  .login-right{padding:32px 20px}
}
/* ===================== END PAGE LOGIN STYLE ===================== */

