@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.hero-wrapper{background:linear-gradient(135deg,#0d6efd,#6610f2);justify-content:center;align-items:center;height:100vh;font-family:Segoe UI,system-ui,sans-serif;display:flex;position:relative;overflow:hidden}.bg-overlay{pointer-events:none;background:radial-gradient(circle at 20% 20%,#0e0c0c2e,#0000 40%),radial-gradient(circle at 80% 80%,#ffffff1f,#0000 40%);animation:8s ease-in-out infinite float;position:absolute;inset:0}.hero-card{text-align:center;z-index:1;background:#fff;border-radius:18px;width:90%;max-width:420px;padding:50px 40px;animation:1s forwards fadeUp;box-shadow:0 20px 50px #00000040}.hero-title{color:#212529;margin-bottom:12px;font-size:2.6rem;font-weight:700}.hero-title span{color:#0d6efd}.cta-btn-custom{color:#fff;background:linear-gradient(135deg,#0d6efd,#6610f2);border:none;border-radius:30px;padding:14px 30px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .25s;display:inline-block;box-shadow:0 8px 20px #0d6efd73}.cta-btn-custom:hover{color:#fff;transform:scale(1.06);box-shadow:0 12px 28px #0d6efd99}:root{--card-radius:14px;--accent:#0b6cff;--muted:#6c757d}.register-page-wrapper{background:radial-gradient(900px 420px at 5% 10%,#0b6cff0a,#0000 8%),radial-gradient(700px 320px at 95% 90%,#00c89605,#0000 6%),#f6f8fb;justify-content:center;align-items:center;min-height:100vh;padding:2rem;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;display:flex}.card-auth{border-radius:var(--card-radius);background:linear-gradient(#fff,#fbfdff);border:1px solid #fffc;width:100%;max-width:520px;overflow:hidden;box-shadow:0 12px 40px #0f16280f}.brand{background:linear-gradient(90deg,#0b6cff08,#00c89603);border-bottom:1px solid #0f162805;align-items:center;gap:12px;padding:18px 20px;display:flex}.brand img{object-fit:cover;border-radius:10px;width:48px;height:48px}.brand h1{color:#07304b;margin:0;font-size:1.05rem;font-weight:700}.brand p{color:var(--muted);margin:0;font-size:.85rem}.card-body-auth{padding:1.4rem 1.6rem}.form-label{color:#123044;font-weight:600}.text-muted-custom{color:var(--muted);font-size:.88rem}.strength{background:#0000000f;border-radius:6px;height:6px;margin-top:8px;overflow:hidden}.strength>span{width:0;height:100%;transition:width .3s,background-color .3s;display:block}.strength.weak span{background:#ff6b6b;width:33%}.strength.fair span{background:#ffb86b;width:66%}.strength.strong span{background:#6be08a;width:100%}.footer-note{color:var(--muted);text-align:center;border-top:1px solid #0f162805;padding:14px;font-size:.86rem}@media (max-width:540px){.register-page-wrapper{padding:1rem}.brand p{display:none}.card-auth{max-width:420px}}.reset-wrapper{margin-top:5rem;animation:.6s both fadeUp}.reset-card{background-color:#fff;border:none;border-radius:16px;overflow:hidden;box-shadow:0 14px 40px #0000001f}.reset-card .card-header{color:#fff;text-align:center;background:linear-gradient(135deg,#0d6efd,#0b5ed7);border-bottom:none;padding:1.5rem}.form-control{border-radius:10px;padding:.65rem .75rem;transition:all .25s}.form-control:focus{border-color:#0d6efd;box-shadow:0 0 0 .18rem #0d6efd2e}.password-wrapper{position:relative}.toggle-password{cursor:pointer;color:#6c757d;z-index:10;position:absolute;top:42px;right:12px}.strength-bar{background:#e9ecef;border-radius:5px;height:6px;margin-top:5px;overflow:hidden}.strength-fill{width:0;height:100%;transition:width .4s,background-color .4s}.btn-reset{border-radius:10px;width:100%;padding:.65rem;font-weight:500;transition:all .2s}.btn-reset:hover{transform:translateY(-2px);box-shadow:0 10px 22px #0d6efd59}.custom-modal-backdrop{z-index:9999;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.custom-modal{background:#fff;border-radius:14px;width:90%;max-width:520px;animation:.25s modalPop;overflow:hidden;box-shadow:0 10px 40px #0000004d}.custom-modal-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:14px 18px;font-weight:600;display:flex}.close-btn{cursor:pointer;background:0 0;border:none;font-size:22px}.custom-modal-body{max-height:70vh;padding:18px;overflow-y:auto}@keyframes modalPop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.stops-list{margin:0;padding:0;list-style:none}.stop-row{border-bottom:1px solid #eee;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:10px 6px;font-size:.95rem;display:grid}.stop-left{align-items:center;gap:8px;display:flex}.stop-dot{background:#9ca3af;border-radius:50%;width:8px;height:8px}.stop-name{font-size:.9rem;font-weight:600}.stop-right{text-align:right}.stop-time{color:#fff;background:#111827;border-radius:999px;padding:4px 8px;font-size:.75rem;font-weight:600}.stop-row.current{background:#e6f4ff;border-radius:8px;animation:1.8s infinite pulse}.stop-row.current .stop-dot{background:#0d6efd}.stop-row.next .stop-dot{background:#16a34a}.stop-row.passed{opacity:.55}.origin-stop .stop-name:before{content:"📍 "}.destination-stop .stop-name:before{content:"🏁 "}.search-stop{background:#fff8e1;border-left:4px solid #ffc107}.bus-icon{margin-left:6px;animation:1.2s ease-in-out infinite busMove}.badge{border-radius:999px;padding:3px 8px;font-size:.7rem;font-weight:600}.badge.reached{background:#f1f3f5}.badge.current{color:#0d6efd;background:#e3f2fd}.badge.moving{color:#2e7d32;background:#e8f5e9}@keyframes pulse{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(2.6)}}@keyframes busMove{0%{transform:translate(0)}50%{transform:translate(4px)}to{transform:translate(0)}}@media (max-width:576px){.stop-row{padding:12px 6px;font-size:.88rem}.stop-time{font-size:.7rem}}button:focus-visible,.popular-card:focus-visible{outline-offset:3px;outline:2px solid #0d6efd}@media (prefers-reduced-motion:reduce){.bus-count-toast,.skeleton-card,.bus-image,.popular-card{transition:none!important;animation:none!important}}.routes-search{margin-bottom:40px}.popular-section:before{content:"";background:#e5e7eb;width:100%;height:1px;margin-bottom:28px;display:block}.popular-section{margin-top:56px}.popular-title{color:#212529;margin-bottom:32px;font-size:2rem;font-weight:800}.popular-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:14px;height:100%;padding:28px 22px;transition:all .2s}.popular-card:hover{border-color:#d1d5db;transform:translateY(-6px);box-shadow:0 14px 32px #00000014}.popular-icon{margin-bottom:14px;font-size:36px}.popular-route{color:#0d6efd;margin-bottom:6px;font-size:1.1rem;font-weight:700;text-decoration:underline}.popular-subtitle{color:#6b7280;font-size:.95rem;line-height:1.5}.popular-card:focus-visible{outline-offset:3px;outline:2px solid #0d6efd}@media (max-width:576px){.popular-title{font-size:1.6rem}.popular-card{padding:22px}.popular-icon{font-size:32px}}.favorite-btn{cursor:pointer;color:#9ca3af;background:0 0;border:none;padding:4px;font-size:1.1rem;transition:transform .18s,color .18s}.favorite-btn:hover{color:#f59e0b;transform:scale(1.15)}.favorite-btn.favorited{color:#f59e0b;animation:.35s fav-bounce,1.2s fav-glow}.favorite-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;filter:grayscale()}@keyframes fav-bounce{0%{transform:scale(1)}40%{transform:scale(1.35)}70%{transform:scale(.95)}to{transform:scale(1)}}@keyframes fav-glow{0%{text-shadow:0 0 #f59e0b00}50%{text-shadow:0 0 10px #f59e0bcc}to{text-shadow:0 0 #f59e0b00}}.bus-count-toast{color:#fff;z-index:9999;background:#16a34a;border-radius:999px;padding:10px 18px;font-size:.95rem;font-weight:600;animation:.6s forwards slideDown,.6s 4.4s forwards fadeOut;position:fixed;top:16px;left:50%;transform:translate(-50%)translateY(-120%)}@keyframes slideDown{to{transform:translate(-50%)translateY(0)}}@keyframes fadeOut{to{opacity:0}}.skeleton-card{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 37%,#e5e7eb 63%) 0 0/400% 100%;border-radius:14px;height:320px;animation:1.4s infinite skeleton}@keyframes skeleton{0%{background-position:100% 0}to{background-position:0 0}}body[data-theme=dark] .popular-card{background:#1e1e1e;border-color:#2a2a2a}body[data-theme=dark] .popular-route{color:#60a5fa}body[data-theme=dark] .popular-subtitle{color:#b0b0b0}body[data-theme=dark] .bus-card{background:#111827;border-color:#1f2937}body[data-theme=dark] .bus-card h6{color:#e5e7eb}body[data-theme=dark] .bus-image-wrapper{background:#1f2937}body[data-theme=dark] .bus-count-toast{background:#15803d}body[data-theme=dark] .skeleton-card{background:linear-gradient(90deg,#1f2937 25%,#374151 37%,#1f2937 63%)}#map{position:absolute;inset:0}.bus-marker{color:#fff;background:linear-gradient(#3b82f6,#0366d6);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.bus-marker .pulse{background:#0366d640;border-radius:50%;animation:1.6s infinite pulse;position:absolute;inset:0}.control-panel{z-index:10;background:#fff;border-radius:12px;padding:12px;position:absolute;top:18px;right:18px}@keyframes pulseSoft{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes slideIn{0%{opacity:0;transform:translate(120%)}to{opacity:1;transform:none}}@keyframes slideOut{to{opacity:0;transform:translate(120%)}}.profile-page{animation:.6s both fadeUp}.profile-card,.favorite-card{border:none;border-radius:16px;transition:transform .25s,box-shadow .25s}.profile-card:hover,.favorite-card:hover{transform:translateY(-6px);box-shadow:0 16px 30px #0000001f}.profile-avatar{font-size:5rem;animation:3s infinite pulseSoft}.badge-wrap{flex-wrap:wrap;justify-content:center;gap:.4rem;margin-top:.5rem;display:flex}.user-badge{border-radius:999px;padding:.35rem .6rem;font-size:.7rem;font-weight:700}.badge-head{color:#fff;background:linear-gradient(135deg,#ff9800,#ff5722);box-shadow:0 0 12px #ff572280}.badge-admin{color:#fff;background:#0d6efd}.badge-top{color:#fff;background:#198754}.badge-contributor{color:#fff;background:#6c757d}.level-badge{border-radius:999px;align-items:center;gap:.4rem;padding:.4rem .75rem;font-size:.8rem;font-weight:700;display:inline-flex}.level-bronze{color:#fff;background:linear-gradient(135deg,#cd7f32,#a97142)}.level-silver{color:#263238;background:linear-gradient(135deg,#cfd8dc,#90a4ae)}.level-gold{color:#5d4037;background:linear-gradient(135deg,#ffd54f,#ffb300);box-shadow:0 0 14px #ffc10780}.favorite-route{color:inherit;border-radius:12px;text-decoration:none;transition:all .2s;display:block}.favorite-route:hover{color:inherit;background-color:#f8f9fa;transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.achievement-toast{z-index:9999;background:#fff;border-radius:14px;align-items:center;gap:12px;width:320px;padding:16px 18px;animation:.5s forwards slideIn;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 12px 30px #0003}.achievement-toast.hiding{animation:.5s forwards slideOut}.route-form-container{max-width:1000px;margin:0 auto;padding-bottom:100px;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif}.card{background:#fff;margin-bottom:24px;transition:transform .2s;border:none!important;border-radius:16px!important;overflow:visible!important;box-shadow:0 4px 20px #0000000d!important}.card-header{background:#fff!important;border-bottom:1px solid #f0f4f8!important;border-radius:16px 16px 0 0!important;padding:1.25rem 1.5rem!important}.card-header h4,.card-header h5{color:#1e293b;align-items:center;margin:0;font-size:1.1rem;font-weight:700;display:flex}.form-label{color:#64748b;text-transform:uppercase;letter-spacing:.025em;margin-bottom:8px;font-size:.75rem;font-weight:700}.form-control,.form-select{color:#1e293b;transition:all .2s;background-color:#fff!important;border:2px solid #e2e8f0!important;border-radius:10px!important;padding:10px 14px!important;font-size:.95rem!important}.form-control:focus,.form-select:focus{background-color:#fff!important;border-color:#4f46e5!important;box-shadow:0 0 0 4px #4f46e51a!important}.autocomplete-list{max-height:250px;margin-top:6px;overflow-y:auto;z-index:2000!important;background:#fff!important;border:1px solid #e2e8f0!important;border-radius:12px!important;padding:8px 0!important;box-shadow:0 10px 30px #00000026!important}.list-group-item-action{color:#334155;font-size:.9rem;border:none!important;padding:12px 16px!important}.btn-primary{box-shadow:0 4px 12px #4f46e533;background-color:#4f46e5!important;border:none!important;border-radius:10px!important;padding:10px 24px!important;font-weight:600!important}.btn-primary:hover{transform:translateY(-1px);background-color:#4338ca!important}.btn-soft-primary{color:#3b82f6;background-color:#eff6ff;border:1px dashed #3b82f6;border-radius:10px;padding:12px;transition:all .2s}.btn-soft-primary:hover{background-color:#dbeafe}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background-color:#0f172ab3!important}.modal-content{border:none!important;border-radius:24px!important;box-shadow:0 25px 50px -12px #00000040!important}.table th{color:#64748b;letter-spacing:.05em;background:#f8fafc;font-size:.75rem;font-weight:700;padding:12px!important}.table td{vertical-align:middle;padding:12px 8px!important}.fixed-bottom{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid #e2e8f0;background:#fffc!important}.contribute-container{color:#334155;background-color:#f8fafc;min-height:100vh;padding-bottom:80px;font-family:Inter,Segoe UI,Roboto,sans-serif}.page-title{color:#0f172a;margin-bottom:4px;font-size:1.75rem;font-weight:700}.text-muted{color:#64748b;font-size:.95rem}.custom-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;margin-bottom:28px;overflow:visible;box-shadow:0 4px 12px #0f172a0f}.card-header-custom{padding:18px 24px 10px}.card-header-custom h5{color:#334155;text-transform:uppercase;letter-spacing:.04em;margin:0;font-size:.9rem;font-weight:700}.card-body{padding:20px 24px 24px}.form-label{color:#475569;margin-bottom:6px;font-size:.8rem;font-weight:600}.form-control-custom,.form-select-custom{color:#0f172a;background-color:#fff;border:1px solid #e2e8f0;border-radius:10px;width:100%;padding:12px 14px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.form-control-custom:focus,.form-select-custom:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb26}.form-control-custom[readonly]{color:#64748b;cursor:not-allowed;background-color:#f1f5f9}.force-uppercase{text-transform:uppercase}.autocomplete-list{z-index:9999;background:#fff;border:1px solid #e2e8f0;border-radius:10px;width:100%;max-height:40vh;padding:4px;position:absolute;top:calc(100% + 6px);overflow-y:auto;box-shadow:0 8px 16px #0f172a1f}.list-group-item-action{cursor:pointer;border:none;border-radius:8px;padding:10px 14px;font-size:.9rem}.list-group-item-action:hover{color:#1d4ed8;background-color:#eff6ff}.stop-row{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;padding:12px 14px}.stop-main{grid-template-columns:1fr 150px;gap:12px;margin-bottom:10px;display:grid}.stop-meta{grid-template-columns:1fr 1fr 90px 40px;align-items:center;gap:10px;display:grid}.stop-meta .form-control-custom{background-color:#f8fafc;font-size:.85rem}.stop-order{text-align:center;background-color:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;font-weight:700}.stop-delete-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stop-delete-btn:hover{color:#ef4444;background-color:#fef2f2}.btn-primary-custom{color:#fff;background-color:#2563eb;border:none;border-radius:12px;padding:14px;font-size:1rem;font-weight:600}.btn-primary-custom:hover{background-color:#1d4ed8}.btn-outline-custom{color:#475569;background:#fff;border:1px dashed #cbd5e1;border-radius:12px;padding:12px;font-weight:600}.btn-outline-custom:hover{color:#2563eb;background-color:#eff6ff;border-color:#2563eb}@media (max-width:1023px){.stop-main{grid-template-columns:1fr}.stop-meta{grid-template-columns:1fr 1fr 90px 40px}}@media (max-width:767px){.page-title{font-size:1.4rem}.custom-card{border-radius:12px}.card-header-custom{padding:14px 16px 6px}.card-body{padding:14px 16px}.stop-row{padding:12px;box-shadow:0 2px 8px #0f172a14}.stop-main,.stop-meta{grid-template-columns:1fr;gap:8px}.stop-meta .form-control-custom{font-size:.8rem}.stop-delete-btn{background-color:#f8fafc;border:1px dashed #e2e8f0;width:100%;height:auto;padding:10px}.stop-delete-btn:hover{color:#ef4444;background-color:#fef2f2}.btn-outline-custom,.btn-primary-custom{width:100%}}:root{--accent:#0b6cff;--muted:#6b7a88;--card-radius:12px;--glass:#0b6cff0f}.add-route-btn,.add-route-cta{transition:transform .12s,box-shadow .12s}.add-route-btn:hover,.add-route-cta:hover{transform:translateY(-3px);box-shadow:0 12px 30px #0b6cff1a}.contributions-card{border:none;border-radius:12px;overflow:hidden}.contributions-card .card-body{padding:.8rem}.table thead{z-index:2;background:#fff;position:sticky;top:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translate(0,0)}}.contributions-table tbody tr{opacity:0;border-radius:6px;transition:box-shadow .18s,transform .18s,background .2s;animation:.45s cubic-bezier(.2,.9,.2,1) forwards fadeInUp}.contributions-table tbody tr:hover{background:linear-gradient(90deg,#0b6cff08,#0000);transform:translateY(0)translate(6px);box-shadow:0 10px 28px #0b6cff0f}.badge{transition:transform .18s,box-shadow .18s}.badge.bg-success{box-shadow:0 8px 24px #28a74514}.badge.bg-warning{box-shadow:0 8px 24px #ffc10714}.badge.bg-danger{box-shadow:0 8px 24px #dc354514}@keyframes badgePulse{0%{transform:translateY(0)scale(1)}50%{transform:translateY(-2px)scale(1.03)}to{transform:translateY(0)scale(1)}}.badge.pulse{animation:1.8s infinite badgePulse}.empty-state{position:relative;overflow:hidden}.empty-illustration{color:#c6cdd6;transition:transform .35s cubic-bezier(.2,.9,.2,1),opacity .35s}.empty-state:hover .empty-illustration{color:#e0e6ed;transform:translateY(-6px)rotate(-6deg)}.add-route-cta{border-radius:999px}.decorative-accent{opacity:.06;filter:blur(2px)saturate(.9);pointer-events:none;z-index:0;background-image:url(/images/logo.png);background-position:50%;background-size:cover;width:420px;height:240px;position:fixed;top:-40px;right:-60px;transform:rotate(-8deg)}@media (max-width:720px){.contributions-table thead{display:none}.contributions-table tbody tr{background:#fff;border:1px solid #eee;border-radius:10px;margin-bottom:12px;padding:12px;display:block}.contributions-table tbody tr td{border:none;width:100%;padding:.25rem 0;display:block}}@media (prefers-reduced-motion:reduce){.contributions-table tbody tr,.badge.pulse,.empty-illustration,.add-route-btn,.add-route-cta{opacity:1!important;transition:none!important;animation:none!important;transform:none!important}.decorative-accent{display:none}}.manage-users-bg{background:linear-gradient(135deg,#eef2f7,#f8f9fa);min-height:100vh}.custom-card{background:#fff;border:none;border-radius:14px;box-shadow:0 12px 30px #00000014}.table thead{color:#fff;background:#0d6efd}.table tbody tr{transition:all .25s}.table tbody tr:hover{background:#f1f6ff;transform:scale(1.005)}.badge-role{letter-spacing:.5px;border-radius:20px;align-items:center;padding:6px 12px;font-size:.8rem;display:inline-flex}.role-admin{color:#fff;background:linear-gradient(45deg,#dc3545,#ff6b6b)}.role-user{color:#fff;background:linear-gradient(45deg,#6c757d,#adb5bd)}.btn-update{transition:all .2s}.btn-update:hover{transform:translateY(-2px);box-shadow:0 6px 14px #0d6efd59}.success-row{animation:1.5s successGlow}@keyframes successGlow{0%{background-color:#d1e7dd;transform:scale(1.02)}to{background-color:#0000;transform:scale(1)}}.import-export-bg{background:linear-gradient(135deg,#eef2f7,#f8f9fa);min-height:100vh}.page-wrapper{animation:.6s both fadeInUp}.custom-card{background:#fff;border:none;border-radius:12px;transition:transform .2s}.custom-card:hover{transform:translateY(-2px)}.card-header-custom{border-bottom:1px solid #0000000d;padding:1.5rem;border-radius:12px 12px 0 0!important}.danger-card{border:1px solid #dc3545}.danger-header{color:#fff;background:#dc3545}.code-block{color:#d63384;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:15px;font-family:monospace;overflow-x:auto}
