/* KBC Transport System v3 — Frontend CSS */
:root {
    --or: #e8500a; --ord: #c44008; --orl: #fff3ed;
    --ok: #1a7f4b; --er: #c0392b; --in: #1565c0;
    --dk: #1a0f00; --md: #4a3728; --mu: #8a7060;
    --ln: #e8ddd5; --cd: #fff8f4; --r: 10px;
}
.kbct-wrap { max-width:900px; margin:0 auto; padding:20px 16px; font-family:system-ui,-apple-system,sans-serif; }
.kbct-wrap h2 { font-size:1.5rem; font-weight:800; color:var(--dk); margin-bottom:6px; }
.kbct-sub  { color:var(--mu); margin-bottom:20px; font-size:0.9rem; }
/* Form */
.kbct-section { font-size:0.72rem; font-weight:700; color:var(--or); text-transform:uppercase; letter-spacing:.07em; border-bottom:2px solid var(--orl); padding-bottom:5px; margin:20px 0 12px; }
.kbct-fr { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px; }
.kbct-ff { margin-bottom:12px; }
.kbct-fr>div>label, .kbct-ff>label { display:block; font-size:0.8rem; font-weight:600; color:var(--md); margin-bottom:4px; }
.kbct-req { color:var(--er); }
.kbct-wrap input[type=text], .kbct-wrap input[type=email], .kbct-wrap input[type=tel],
.kbct-wrap input[type=number], .kbct-wrap input[type=date], .kbct-wrap input[type=password],
.kbct-wrap select, .kbct-wrap textarea {
    width:100%; padding:9px 12px; border:1.5px solid var(--ln); border-radius:var(--r);
    font-size:0.88rem; font-family:inherit; color:var(--dk); background:#fff; outline:none; box-sizing:border-box;
}
.kbct-wrap input:focus, .kbct-wrap select:focus, .kbct-wrap textarea:focus { border-color:var(--or); }
.kbct-wrap textarea { resize:vertical; min-height:72px; }
.kbct-file { display:flex; align-items:center; gap:8px; padding:9px 12px; border:1.5px dashed var(--ln); border-radius:var(--r); cursor:pointer; font-size:0.83rem; color:var(--mu); }
.kbct-file:hover { border-color:var(--or); color:var(--or); background:var(--orl); }
.kbct-file input { display:none; }
/* Buttons */
.kbct-btn { display:inline-flex; align-items:center; gap:6px; padding:9px 20px; border-radius:var(--r); font-size:0.88rem; font-weight:700; cursor:pointer; border:2px solid transparent; font-family:inherit; transition:all .15s; text-decoration:none; }
.kbct-btn-primary { background:var(--or); color:#fff; border-color:var(--or); }
.kbct-btn-primary:hover { background:var(--ord); }
.kbct-btn-outline  { background:transparent; border-color:var(--or); color:var(--or); }
.kbct-btn-outline:hover { background:var(--orl); }
.kbct-btn-wa  { background:#25d366; color:#fff; border-color:#25d366; }
.kbct-btn-ok  { background:var(--ok); color:#fff; }
.kbct-btn-er  { background:var(--er); color:#fff; }
.kbct-btn-sm  { padding:6px 12px; font-size:0.78rem; }
/* Messages */
.kbct-msg { padding:11px 14px; border-radius:var(--r); margin-bottom:14px; font-size:0.85rem; display:none; border-left:4px solid; }
.kbct-msg-ok { background:#e8f5ee; border-color:var(--ok); color:#155724; display:block; }
.kbct-msg-er { background:#fdecea; border-color:var(--er); color:#721c24; display:block; }
/* Badges */
.kbct-badge { display:inline-block; padding:3px 9px; border-radius:20px; font-size:0.71rem; font-weight:700; }
.kbct-ok { background:#e8f5ee; color:#155724; }
.kbct-er { background:#fdecea; color:#721c24; }
.kbct-wa { background:#fff3cd; color:#856404; }
.kbct-in { background:#e3f2fd; color:#0d47a1; }
/* Notices */
.kbct-notice { padding:11px 15px; border-radius:var(--r); margin-bottom:14px; font-size:0.85rem; border-left:4px solid; }
.kbct-notice-warning { background:#fff8e1; border-color:#e65100; color:#6d4c00; }
.kbct-notice-ok      { background:#e8f5ee; border-color:var(--ok); color:#1a5c37; }
.kbct-notice-info    { background:#e3f2fd; border-color:var(--in); color:#0d47a1; }
/* Search */
.kbct-search-box { background:linear-gradient(135deg,#fff5ee,#fff3ed); border:1.5px solid #fad4bc; border-radius:16px; padding:22px; margin-bottom:22px; }
.kbct-search-row { display:flex; gap:9px; flex-wrap:wrap; }
.kbct-search-row select, .kbct-search-row input { flex:1; min-width:130px; padding:9px 11px; border:1.5px solid var(--ln); border-radius:var(--r); font-size:0.85rem; font-family:inherit; }
.kbct-hint { color:var(--mu); text-align:center; padding:28px; }
.kbct-tiada { text-align:center; padding:28px; color:var(--mu); }
/* Cards */
.kbct-kad-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.kbct-kad { background:#fff; border:1.5px solid var(--ln); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; }
.kbct-kad:hover { border-color:var(--or); }
.kbct-kad-h { background:var(--or); padding:13px 15px; display:flex; justify-content:space-between; align-items:flex-start; gap:8px; }
.kbct-kad-h h3 { color:#fff; font-size:0.9rem; font-weight:700; margin:0; flex:1; }
.kbct-jenis { background:rgba(255,255,255,.22); color:#fff; padding:2px 8px; border-radius:5px; font-size:0.69rem; font-weight:700; }
.kbct-kad-b { padding:13px 15px; flex:1; }
.kbct-kad-b p { font-size:0.8rem; color:var(--md); margin:3px 0; }
.kbct-kad-b p strong { color:var(--dk); min-width:72px; display:inline-block; font-size:0.78rem; }
.kbct-stars { color:#f0a500; font-size:0.9rem; margin-bottom:5px !important; }
.kbct-stars span { font-size:0.74rem; color:var(--mu); }
.kbct-harga { font-size:1.1rem; font-weight:800; color:var(--or); margin-top:8px !important; }
.kbct-slot { font-size:0.74rem; color:var(--ok); }
.kbct-krit { color:var(--er); font-weight:700; }
.kbct-penuh { font-size:0.8rem; color:var(--mu); align-self:center; }
.kbct-kad-f { padding:11px 15px; border-top:1px solid var(--ln); display:flex; gap:7px; }
.kbct-kad-f .kbct-btn { flex:1; justify-content:center; padding:8px; font-size:0.8rem; }
/* Modal */
.kbct-modal { position:relative; }
.kbct-modal-bg { position:fixed; inset:0; background:rgba(26,15,0,.5); z-index:200; }
.kbct-modal-box { position:fixed; top:50%; left:50%; transform:translate(-50%,-50%); background:#fff; border-radius:16px; padding:24px; width:90%; max-width:560px; max-height:88vh; overflow-y:auto; z-index:201; }
.kbct-modal-tutup { position:absolute; top:13px; right:14px; background:var(--orl); border:none; width:27px; height:27px; border-radius:50%; cursor:pointer; font-size:1rem; color:var(--or); }
.kbct-jumlah { background:var(--orl); border:1.5px solid #fad4bc; border-radius:var(--r); padding:9px 12px; font-size:1rem; font-weight:800; color:var(--or); }
/* Portal */
.kbct-portal-header { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:10px; margin-bottom:20px; }
.kbct-portal-header h2 { font-size:1.5rem; font-weight:800; }
.kbct-portal-header p { color:var(--mu); font-size:0.85rem; }
.kbct-tabs { display:flex; gap:3px; border-bottom:2px solid var(--ln); margin-bottom:20px; overflow-x:auto; }
.kbct-tab { padding:9px 16px; font-size:0.83rem; font-weight:600; cursor:pointer; color:var(--mu); border-bottom:3px solid transparent; margin-bottom:-2px; text-decoration:none; white-space:nowrap; }
.kbct-tab-aktif { color:var(--or); border-bottom-color:var(--or); }
/* Stats */
.kbct-stat-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px; margin-bottom:20px; }
.kbct-stat { background:var(--cd); border:1.5px solid var(--ln); border-radius:16px; padding:15px; text-align:center; }
.kbct-stat-n { font-size:1.8rem; font-weight:800; color:var(--or); }
.kbct-stat-l { font-size:0.74rem; color:var(--mu); margin-top:2px; }
.kbct-stat a { display:block; font-size:0.76rem; color:var(--in); margin-top:6px; }
/* Table */
.kbct-tbl { width:100%; border-collapse:collapse; font-size:0.83rem; }
.kbct-tbl thead th { background:#f5ede7; color:var(--md); font-weight:700; padding:9px 10px; text-align:left; border-bottom:2px solid var(--ln); }
.kbct-tbl tbody td { padding:9px 10px; border-bottom:1px solid #f0ebe6; vertical-align:middle; }
.kbct-tbl tbody tr:hover { background:#fff8f4; }
.kbct-wa { color:#25d366; font-weight:600; font-size:0.8rem; text-decoration:none; }
/* Floating WA */
#kbct-wa-float { position:fixed; bottom:24px; right:24px; z-index:999; background:#25d366; color:#fff; border-radius:50px; padding:12px 18px; display:flex; align-items:center; gap:7px; font-size:0.85rem; font-weight:700; text-decoration:none; box-shadow:0 4px 18px rgba(37,211,102,.4); }
#kbct-wa-float:hover { background:#1da851; }
@media(max-width:600px) {
    .kbct-fr { grid-template-columns:1fr; }
    .kbct-kad-grid { grid-template-columns:1fr; }
    .kbct-search-row { flex-direction:column; }
    #kbct-wa-float span.kbct-wa-lbl { display:none; }
}
