@import"https://fonts.googleapis.com/css2?family=Fira+Sans:wght@400;500;600;700&display=swap";.chat-bubble-fab{position:fixed;bottom:100px;right:20px;width:60px;height:60px;border-radius:50%;background:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #3b82f666;cursor:pointer;z-index:9999;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.chat-bubble-fab:hover{transform:scale(1.1)}.chat-window{position:fixed;bottom:100px;right:20px;width:350px;height:500px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;z-index:1001;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-header{background:#fff;color:#1e293b;border-bottom:1px solid rgba(0,0,0,.1);padding:12px 16px;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:8px}.live-dot{width:8px;height:8px;background:#ef4444;border-radius:50%;animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(.9);opacity:.7}50%{transform:scale(1.1);opacity:1}to{transform:scale(.9);opacity:.7}}.chat-header h3{margin:0;font-size:.9rem;color:#0f172a;font-weight:700}.close-chat{background:none;border:none;color:#64748b;cursor:pointer;padding:5px;display:flex}.chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;background:#fff}.yt-message{display:flex;gap:12px;padding:4px 0;align-items:flex-start}.yt-avatar{width:24px;height:24px;min-width:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:700}.yt-message-content{display:flex;flex-direction:column;flex:1;min-width:0}.yt-msg-header{display:flex;align-items:baseline;gap:8px}.yt-msg-body{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}.yt-username{font-weight:700;font-size:.8rem;white-space:nowrap;opacity:.7}.yt-timestamp{font-size:.7rem;color:#94a3b8;display:none}.yt-text{font-size:.85rem;color:#334155;word-break:break-word;line-height:1.4;flex:1}.yt-msg-time-right{font-size:.65rem;color:#94a3b8;white-space:nowrap;margin-bottom:2px}.live-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;font-size:8px;padding:2px 6px;border-radius:4px;font-weight:800;letter-spacing:.5px;box-shadow:0 2px 5px #ef444466}.chat-input-area{padding:12px 16px;background:#f8fafc;display:flex;gap:10px;border-top:1px solid rgba(0,0,0,.05)}.chat-input-area input{flex:1;border:1px solid #e2e8f0;background:#f1f5f9;padding:8px 12px;border-radius:4px;outline:none;font-size:.85rem}.send-btn{background:none;border:none;color:#3b82f6;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s}.send-btn:hover:not(:disabled){color:#2563eb}.send-btn:disabled{opacity:.4;cursor:default}.login-required-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:20px;color:#64748b}.login-required-msg button{margin-top:12px;padding:6px 12px;background:#3b82f6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.85rem}@media(max-width:480px){.chat-window{width:calc(100vw - 40px);height:60vh;bottom:80px}}.layout-container{display:flex;flex-direction:column;min-height:100vh;background:var(--bg-app);position:relative;padding-bottom:80px}.layout-container.premium-view{background:var(--bg-app);position:relative;transition:background .3s ease-in-out}.layout-container.premium-view:before{content:"";position:fixed;inset:0;background:transparent;z-index:1;pointer-events:none;transition:background 1.2s ease}.layout-container.morning,.layout-container.day,.layout-container.afternoon,.layout-container.night{filter:none}.content{flex:1;padding:1.5rem;display:flex;flex-direction:column;align-items:center;position:relative;z-index:10;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:var(--bg-card);display:flex;justify-content:space-around;align-items:center;box-shadow:0 -10px 30px #0000000d;z-index:1000;padding:0 10px;border-radius:2rem 2rem 0 0;border-top:1px solid var(--border)}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:#94a3b8;text-decoration:none;transition:var(--transition);font-size:.7rem;font-weight:600}.nav-item.active{color:var(--accent)}.nav-item svg{width:24px;height:24px}.qris-btn-container{position:relative;top:-25px;filter:drop-shadow(0 8px 15px rgba(30,58,138,.3))}.qris-btn{width:65px;height:65px;background:var(--bg-vibrant-blue);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;border:4px solid #ffffff;cursor:pointer;transition:var(--transition)}.qris-btn:hover{transform:scale(1.05)}.qris-btn span{font-size:.6rem;font-weight:900;letter-spacing:1px}@media(max-width:768px){.premium-header{display:none}.content{padding:1rem}}@media(min-width:769px){.premium-header{width:100%;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;position:fixed;top:0;left:0;right:0;z-index:100;background:var(--header-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.premium-logo{color:var(--text-primary);font-size:1.5rem;font-weight:800;text-decoration:none}.premium-nav{display:flex;gap:1.5rem}.premium-nav-item{color:var(--text-secondary);text-decoration:none;font-weight:700;transition:var(--transition);display:flex;align-items:center}.premium-nav-item.active{color:var(--accent)}.theme-toggle-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.theme-toggle-btn:hover{transform:scale(1.05);border-color:var(--accent);color:var(--accent)}}.dashboard-container{width:100%;display:flex;flex-direction:column;align-items:center;color:#1e293b;padding-bottom:2rem}.dashboard-inner{width:100%;max-width:500px;display:flex;flex-direction:column;gap:1.25rem}.greeting-section{padding:1rem 0;color:#1e293b}.greeting-section h2{font-size:1.5rem;font-weight:800}.total-stat{display:none}.chart-card{background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.3);position:relative;overflow:hidden;transition:var(--transition)}.chart-card:hover{background:#ffffffe6}.chart-header h3{font-size:1.1rem;font-weight:800;color:#1e293b;margin-bottom:.5rem}.chart-total-badge{display:none}.recharts-bar-rectangle{transition:all .3s ease}.journey-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:var(--transition)}.journey-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.journey-header h3{font-size:.95rem;font-weight:800;color:var(--text-primary)}.journey-table{width:100%;border-collapse:collapse}.journey-table th{text-align:left;font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.journey-table td{padding:1rem 0;border-bottom:1px solid var(--border)}.journey-table tr:last-child td{border-bottom:none;padding-bottom:0}.badge-mudik,.badge-balik{font-size:.65rem;font-weight:800;padding:4px 8px;border-radius:6px;text-transform:uppercase}.badge-mudik{background:#3b82f61a;color:#3b82f6}.badge-balik{background:#10b9811a;color:#10b981}.route-text{display:flex;flex-direction:column}.route-text strong{font-size:.9rem;color:var(--text-primary)}.route-text small{font-size:.75rem;color:var(--text-secondary)}.status-pill{font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:20px}.status-pill.berangkat{background:#fefce8;color:#a16207}.status-pill.sampai{background:#f0fdf4;color:#15803d}.status-pill.balik{background:#f5f3ff;color:#6d28d2}.status-card.clickable{cursor:pointer;transition:var(--transition)}.status-card.clickable:hover{transform:scale(1.02);border-color:var(--accent)}.menu-grid-card{background:#fff;border-radius:var(--radius-lg);padding:2rem 1.5rem;box-shadow:var(--shadow-lg)}.menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem .5rem}.menu-item{display:flex;flex-direction:column;align-items:center;gap:.75rem;background:none;border:none;cursor:pointer;transition:var(--transition)}.menu-item:hover{transform:translateY(-5px)}.menu-item .icon-circle{width:55px;height:55px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;filter:drop-shadow(0 5px 10px rgba(0,0,0,.05))}.menu-item span{font-size:.65rem;font-weight:700;color:#475569;text-align:center;white-space:nowrap}.bg-teal{background:#4fd1c5}.bg-indigo{background:#667eea}.bg-blue-soft{background:#4ba2ff}.bg-pink{background:#f687b3}.bg-rose{background:#f56565}.bg-cyan{background:#00bcd4}.bg-violet{background:#9f7aea}.bg-blue-dark{background:#3182ce}.carousel-indicators{margin-top:1rem}.carousel-indicators .dot{width:6px;height:6px;background:#cbd5e1;border:none;border-radius:50%;margin:0 4px;cursor:pointer;transition:all .3s ease}.carousel-indicators .dot.active{width:20px;border-radius:10px;background:#3b82f6}@media(max-width:400px){.menu-grid{gap:1rem 0}.menu-item .icon-circle{width:48px;height:48px}}.login-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 80px)}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:3rem;width:100%;max-width:400px;text-align:center;box-shadow:var(--shadow-lg);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.login-logo{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem}.login-logo h1{font-size:1.5rem;font-weight:800;color:var(--text-primary)}.login-content h2{font-size:1.75rem;margin-bottom:.5rem}.login-content p{color:var(--text-secondary);margin-bottom:2rem}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;border-radius:var(--radius-md);border:1px solid var(--border);background:#fff;color:#374151;font-weight:600;cursor:pointer;transition:var(--transition)}.btn-google:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:var(--shadow)}.login-footer{margin-top:3rem;font-size:.75rem;color:var(--text-secondary);opacity:.6}.form-container{width:100%;max-width:700px;margin:0 auto;padding:3rem 1rem;min-height:100vh}.form-header{text-align:center;margin-bottom:3.5rem}.form-header h1{font-size:3.5rem;font-weight:900;margin-bottom:.5rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.1em;text-shadow:0 10px 30px rgba(0,0,0,.1)}.form-header p{color:var(--text-secondary);font-size:1.25rem;font-weight:600}.premium-form-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:3.5rem;box-shadow:var(--shadow-lg);border:1px solid var(--border);position:relative;overflow:hidden;z-index:20}.premium-form-card:after{content:"";position:absolute;top:0;left:0;width:100%;height:10px;background:linear-gradient(90deg,#ff4d4d,#f9cb28,#3b82f6)}.mudik-form .form-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.input-group{display:flex;flex-direction:column;gap:.8rem}.input-group.full{grid-column:1 / -1}.input-group label{font-size:.95rem;font-weight:900;color:var(--text-primary);display:flex;align-items:center;gap:.75rem;text-transform:uppercase;letter-spacing:.05em}.input-group label svg{color:var(--accent);filter:drop-shadow(0 2px 4px rgba(59,130,246,.2))}.input-group input,.input-group select{width:100%;padding:1.25rem;border-radius:1.25rem;border:3px solid var(--border);background:var(--bg-card);color:var(--text-primary);font-size:1.1rem;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 2px 4px #00000005}.input-group input:hover,.input-group select:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 20px -5px #0000000d}.input-group input:focus,.input-group select:focus{border-color:var(--accent);background:var(--bg-card);outline:none;box-shadow:0 0 0 5px var(--accent-soft),0 20px 25px -5px #0000001a;transform:translateY(-2px)}.btn-submit{width:100%;margin-top:3rem;background:linear-gradient(135deg,var(--accent) 0%,#1e3a8a 100%);color:#fff;border:none;padding:1.5rem;border-radius:1.5rem;font-size:1.3rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 20px 40px -10px #0f172a4d}.btn-submit:hover:not(:disabled){background:linear-gradient(135deg,#3b82f6,#2563eb);transform:translateY(-5px) scale(1.02);box-shadow:0 25px 50px -12px #2563eb66}@media(max-width:640px){.premium-form-card{padding:2rem 1.5rem;border-radius:2rem}.mudik-form .form-grid{grid-template-columns:1fr;gap:1.5rem}.form-header h1{font-size:2.25rem}.input-group input,.input-group select{padding:1rem;font-size:1rem}}.donasi-container{max-width:500px;margin:0 auto;padding:1rem;min-height:80vh;display:flex;flex-direction:column}.donasi-header{margin-bottom:2rem;position:relative;padding-top:1rem}.btn-back{display:flex;align-items:center;gap:.5rem;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);padding:.6rem 1.2rem;border-radius:1rem;cursor:pointer;font-weight:700;transition:var(--transition);box-shadow:var(--shadow-sm)}.btn-back:hover{background:var(--accent-soft);color:var(--accent)}.donasi-header h1{font-size:2rem;color:var(--text-primary);font-weight:800;margin-top:2rem;text-align:center}.donation-wrapper{flex:1;display:flex;flex-direction:column;justify-content:center;gap:2rem}.trakteer-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:3rem 2rem;text-align:center;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:1.5rem;transition:var(--transition)}.trakteer-card:hover{transform:translateY(-5px)}.trakteer-icon{width:100px;height:100px;background:#fff1f2;color:#e11d48;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #e11d4866}70%{transform:scale(1.05);box-shadow:0 0 0 15px #e11d4800}to{transform:scale(1);box-shadow:0 0 #e11d4800}}.trakteer-content h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:1rem;font-weight:800}.trakteer-content p{color:var(--text-secondary);line-height:1.6;margin-bottom:2rem;font-size:1rem}.trakteer-link{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;background:linear-gradient(135deg,#e11d48,#be123c);color:#fff;padding:1rem 2.5rem;border-radius:1.5rem;text-decoration:none;font-weight:800;font-size:1.1rem;transition:var(--transition);box-shadow:0 10px 20px #e11d484d}.trakteer-link:hover{transform:scale(1.05);box-shadow:0 15px 25px #e11d4866}.social-proof{text-align:center;font-style:italic;color:var(--text-secondary);opacity:.7;font-size:.9rem;font-weight:600}.profile-container{width:100%;display:flex;flex-direction:column;align-items:center;padding-bottom:5rem}.profile-inner{width:100%;max-width:500px;display:flex;flex-direction:column;gap:1.5rem}.profile-header-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:var(--shadow-md);border:1px solid var(--border);margin-top:1rem}.avatar-large{width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:800;margin-bottom:1rem;box-shadow:0 8px 20px #3b82f64d}.profile-basics h2{font-size:1.5rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem}.profile-info-row{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.profile-badge{display:inline-block;padding:4px 12px;background:#3b82f61a;color:#3b82f6;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase}.profile-journey{margin-top:.5rem}.profile-loading,.empty-profile-status{padding:2rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.btn-primary-sm{margin-top:1rem;padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:700;cursor:pointer;font-size:.85rem}.profile-settings-hint{text-align:center;padding:1rem;border:1px dashed var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8rem}.stats-page-container{width:100%;display:flex;flex-direction:column;align-items:center;padding-bottom:6rem}.stats-page-inner{width:100%;max-width:650px;display:flex;flex-direction:column;gap:1.75rem;padding:0 1rem}.stats-grid{display:flex;flex-direction:column;gap:1.5rem}.stats-title-section{padding:2rem 0 .5rem;text-align:left}.stats-title-section h2{font-size:1.85rem;font-weight:800;color:var(--text-primary);margin-bottom:.25rem}.stats-title-section p{color:var(--text-secondary);font-size:.95rem;opacity:.8}.stats-chart-card{background:#fff;border-radius:20px;padding:1.75rem;box-shadow:0 10px 40px #0000000f;border:1px solid rgba(0,0,0,.05);transition:transform .3s ease,box-shadow .3s ease}.stats-chart-card:hover{transform:translateY(-4px);box-shadow:0 15px 40px #00000014}.stats-chart-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem}.stats-icon-wrapper{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #0000000d}.stats-chart-header h3{font-size:1.15rem;font-weight:800;color:var(--text-primary);margin:0}.stats-icon{color:#3b82f6}.stats-loading{padding:5rem;text-align:center;color:var(--text-secondary);font-weight:600}.empty-stats-placeholder{height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-secondary)}.empty-stats-placeholder p{font-size:.85rem}:root{--bg-app: #f8fafc;--bg-card: #ffffff;--bg-vibrant-blue: linear-gradient(210deg, #1e3a8a 0%, #3b82f6 100%);--bg-gradient: var(--bg-vibrant-blue);--text-primary: #0f172a;--text-secondary: #475569;--text-on-gradient: #ffffff;--accent: #2563eb;--accent-soft: #eff6ff;--border: #e2e8f0;--header-bg: rgba(255, 255, 255, .8);--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 10px 15px -3px rgba(0, 0, 0, .05), 0 4px 6px -2px rgba(0, 0, 0, .03);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-lg: 2.5rem;--radius-md: 1.5rem;--transition: all .3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-app: #020617;--bg-card: #0f172a;--bg-gradient: linear-gradient(135deg, #0f172a 0%, #020617 100%);--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-on-gradient: #f8fafc;--accent: #3b82f6;--accent-soft: rgba(59, 130, 246, .1);--border: #1e293b;--header-bg: rgba(15, 23, 42, .8);--shadow: 0 4px 6px -1px rgb(0 0 0 / .5)}*{margin:0;padding:0;box-sizing:border-box;font-family:Fira Sans,sans-serif;-webkit-font-smoothing:antialiased}body{background-color:var(--bg-app);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;min-height:100vh}.premium-gradient{background:var(--bg-gradient);color:var(--text-on-gradient)}.glass-card{background:#ffffff1a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg)}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border);transition:var(--transition)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .5s ease-out forwards}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;padding:1rem}@media(max-width:640px){.dashboard-grid{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.w-full{width:100%}.text-center{text-align:center}.text-muted{color:var(--text-secondary);opacity:.8}.text-sm{font-size:.875rem}.btn-premium{padding:.75rem 1.5rem;border-radius:var(--radius-md);border:none;cursor:pointer;font-weight:600;transition:var(--transition);display:flex;align-items:center;gap:.5rem}.btn-premium:hover{filter:brightness(1.1);transform:scale(1.02)}.btn-premium:active{transform:scale(.98)}
