.weather-info{background-color:#f1f5f9;border-bottom:1px solid #e2e8f0;color:#0f172a;font-size:.95rem;font-weight:500;justify-content:space-between;padding:.6rem 1rem}.weather-info,.weather-left{align-items:center;display:flex}.weather-left{gap:.6rem}.weather-left svg{font-size:1.5rem}.weather-right{color:#ef4444}.header-wrapper{margin-bottom:2rem;text-align:center}.title{align-items:center;color:#0f172a;display:flex;font-size:2rem;font-weight:700;gap:10px;justify-content:center;margin-bottom:.5rem}.title-icon{color:#2563eb;font-size:1.5rem}.header-bottom{align-items:center;display:flex;flex-direction:column;gap:.75rem}.updated-text{color:#64748b;font-size:.875rem}.refresh-button{align-items:center;background-color:#2563eb;border:none;border-radius:9999px;box-shadow:0 2px 5px #0000000f;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;margin:0 auto 2rem;padding:.45rem 1rem;transition:background-color .2s ease}.refresh-button:hover{background-color:#1e40af}.live-dot{animation:pulse 1.2s infinite;background-color:#ef4444;border-radius:50%;box-shadow:0 0 0 0 #ef4444b3;height:10px;margin-left:8px;width:10px}@keyframes pulse{0%{box-shadow:0 0 0 0 #ef4444b3;transform:scale(1)}70%{box-shadow:0 0 0 8px #ef444400;transform:scale(1.1)}to{box-shadow:0 0 0 0 #ef444400;transform:scale(1)}}@media (max-width:480px){.title{font-size:1.5rem}.refresh-button{font-size:.78rem;gap:4px;padding:.35rem .85rem}}.origin-card-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:2rem}.origin-card{background-color:#fff;border-radius:1rem;box-shadow:0 2px 10px #0000000f;padding:1.5rem}.origin-title{color:#1e293b;font-size:1.2rem;font-weight:700;margin-bottom:1rem}.map-preview{border-radius:10px;cursor:pointer;height:180px;margin-bottom:1rem;object-fit:cover;transition:transform .2s ease;width:100%}.map-preview:hover{transform:scale(1.01)}.destination-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr}.destination-card{background-color:#f8fafc;border-left:4px solid #2563eb;border-radius:10px;cursor:pointer;padding:1rem;transition:transform .2s ease,background-color .2s ease}.destination-card:hover{background-color:#eef2ff}.destination-card h4{color:#0f172a;font-size:1rem;font-weight:600;margin-bottom:.6rem;margin-top:0}.destination-card p{color:#334155;font-size:.9rem;margin:.35rem 0}.modal-image-container{box-sizing:border-box;max-width:700px;padding:10px;width:100%}.modal-image{border-radius:10px;box-shadow:0 8px 24px #0003;height:auto;max-height:90vh;object-fit:contain;width:100%}.modal-close-button{background:#ef4444;border:none;border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;font-size:18px;font-weight:700;height:32px;position:absolute;right:10px;top:10px;width:32px;z-index:1000}@media (max-width:768px){.map-preview{height:140px}.destination-card{padding:.85rem}.destination-card p{font-size:.85rem}.origin-title{font-size:1.05rem}}@media (max-width:480px){.map-preview{height:120px}.destination-card h4{font-size:.95rem}.destination-card p{font-size:.8rem}.modal-close-button{font-size:16px;height:28px;right:8px;top:8px;width:28px}}.real-time-chart{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 12px #0000000a;margin:1.5rem 0 2.5rem;padding:1.5rem 1.75rem}.chart-title{align-items:center;color:#0f172a;font-size:1.25rem;font-weight:600;gap:8px}.chart-title,.chart-toggle-buttons{display:flex;justify-content:center;margin-bottom:1.5rem}.chart-toggle-buttons{flex-wrap:wrap;gap:.75rem}.chart-toggle-buttons button{background-color:#e2e8f0;border:none;border-radius:9999px;color:#0f172a;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1.25rem;transition:all .2s ease;white-space:nowrap}.chart-toggle-buttons button:hover{background-color:#cbd5e1}.chart-toggle-buttons button.active{background-color:#ef4444;border-color:#ef4444;color:#fff}.custom-tooltip{background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 4px 8px #0000000f;color:#0f172a;font-size:.85rem;padding:10px}.spinner{align-items:center;color:#0f172a;display:flex;flex-direction:column;justify-content:center;padding:2rem}.loader-circle{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:32px;margin-bottom:10px;width:32px}.spinner-text{color:#475569;font-size:.95rem;font-weight:500}@keyframes spin{to{transform:rotate(1turn)}}.summary-cards{display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:2rem}.summary-card,.summary-cards{justify-content:center;text-align:center}.summary-card{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:.75rem;box-shadow:0 4px 12px #0000000a;flex:1 1;min-width:220px;padding:1.25rem 1.5rem;transition:transform .2s ease}.summary-card:hover{box-shadow:0 6px 16px #00000014;transform:translateY(-2px)}.speed-card{border-left:4px solid #3b82f6}.congestion-card{border-left:4px solid #ef4444}.summary-card h3{align-items:center;color:#0f172a;display:flex;font-size:1.1rem;gap:8px;justify-content:center;margin-bottom:.5rem}.summary-value{color:#1e293b;font-size:1.75rem;font-weight:700}.heatmap-wrapper{background:#f8fafc;border:1px solid #e2e8f0;border-radius:1rem;box-shadow:0 4px 12px #0000000d;font-size:.85rem;margin-top:2rem;padding:1.5rem}.heatmap-title{color:#0f172a;font-size:1.25rem;font-weight:600;gap:8px;justify-content:center;margin-bottom:1.25rem;text-align:center}.heatmap-title,.heatmap-toggle{align-items:center;display:flex}.heatmap-toggle{flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.toggle-left{display:flex;flex-wrap:wrap;gap:10px}.toggle-right{display:flex;flex:1 1;justify-content:flex-end;min-width:200px}.toggle-left button{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:9999px;color:#0f172a;cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem 1.25rem;transition:all .2s ease}.toggle-left button:hover{background-color:#e2e8f0}.toggle-left button.active{background-color:#ef4444;border-color:#ef4444;color:#fff}.week-selector-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.week-label{color:#0f172a;font-weight:500}.week-selector{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:9999px;color:#0f172a;cursor:pointer;font-size:.85rem;padding:.4rem .9rem;transition:all .2s ease}.week-selector:hover{background-color:#e2e8f0;border-color:#94a3b8}.heatmap-scroll{overflow-x:auto;width:100%}.heatmap-table{border-collapse:collapse;font-size:.85rem;font-weight:500;min-width:700px;text-align:center;width:100%}.heatmap-table td,.heatmap-table th{background-color:#fff;border:1px solid #e2e8f0;color:#0f172a;min-width:80px;padding:8px}@media (max-width:768px){.heatmap-toggle{align-items:stretch;flex-direction:column;gap:1rem}.toggle-left,.toggle-right,.week-selector-wrapper{justify-content:center}.toggle-left button{font-size:.8rem;padding:.45rem 1rem;width:100%}.week-selector{font-size:.8rem;text-align:center;width:100%}.heatmap-table td,.heatmap-table th{font-size:.75rem;padding:6px}}@media (max-width:480px){.heatmap-table{min-width:100%}.toggle-left button{font-size:.75rem;padding:.4rem .8rem}.week-selector{font-size:.75rem}.heatmap-table td,.heatmap-table th{font-size:.7rem;padding:5px}}.rush-hour-wrapper{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:2rem}.rush-hour-section{margin-bottom:2.5rem;margin-top:3rem;text-align:center}.rush-hour-title{color:#0f172a;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.rush-card{background-color:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;flex:1 1;max-width:400px;min-width:280px;padding:1.5rem;text-align:center}.rush-label{color:#dc2626;font-size:.9rem;font-weight:700;margin-bottom:.25rem}.rush-time{color:#0f172a;font-size:1.4rem;font-weight:700;margin-bottom:1rem}.rush-image img{margin-bottom:1.5rem;width:100px}.rush-stats p{color:#334155;font-size:.95rem;margin:.75rem 0}.rush-stats strong{color:#0f172a;font-size:1.25rem}.footer{background-color:#fff;border-top:1px solid #e2e8f0;bottom:0;box-shadow:0 -2px 6px #0000000f;left:0;padding:.6rem 1rem;position:fixed;text-align:center;width:100%;z-index:1000}.footer-content{align-items:center;display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:center}.footer-logo{height:auto;object-fit:contain}.logo-intrast{max-height:28px}.logo-prishtina{margin-bottom:-4px;max-height:52px}.footer-text{color:#64748b;font-size:.75rem;margin-top:.25rem}@media (max-width:480px){.footer-content{gap:1.5rem}.logo-intrast{max-height:30px}.logo-prishtina{max-height:42px}.footer-text{font-size:.7rem}}body{background-color:#fff;color:#1e293b;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1rem;margin:0;padding:20px 20px 100px}.container{margin:auto;max-width:1000px;padding:1rem}.section-spacing{margin-bottom:5rem}.origin-section{margin-bottom:2.5rem;margin-top:3rem}.origin-section-title{color:#0f172a;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem;text-align:center}.scroll-to-top-modern{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffbf;border:1px solid #e2e8f0;border-radius:9999px;bottom:1.5rem;box-shadow:0 6px 16px #00000014;color:#0f172a;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;overflow:hidden;padding:.6rem .75rem;position:fixed;right:1.5rem;transition:all .3s ease;z-index:999}.scroll-to-top-modern .scroll-label{opacity:0;overflow:hidden;transition:all .3s ease;width:0}.scroll-to-top-modern:hover{background-color:#e2e8f0;padding-right:1rem}.scroll-to-top-modern:hover .scroll-label{opacity:1;width:auto}.scroll-icon{color:#2563eb;font-size:1rem}@media (max-width:1024px){.container{padding:1.5rem}.chart-toggle-buttons button{font-size:.8rem}}@media (max-width:768px){.title{font-size:1.5rem}.origin-card-grid{grid-template-columns:1fr}.chart-toggle-buttons{align-items:center;flex-direction:column;gap:.5rem}.chart-toggle-buttons button{text-align:center;width:70%}.summary-cards{align-items:stretch;flex-direction:column}}@media (max-width:480px){.refresh-button{width:100%}.chart-title{font-size:1.1rem}.summary-card h3,.summary-value{font-size:1rem}.list-item{font-size:.95rem}.list-item strong{font-size:1rem}.destination-card{font-size:.85rem;padding:.8rem}.destination-card h4{font-size:.95rem}.scroll-to-top-modern{bottom:1rem;padding:.5rem;right:1rem}.scroll-to-top-modern:hover .scroll-label{display:none}}.chart-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.chart-header h2{color:#0f172a;flex:1 1;font-size:1.1rem;font-weight:600;margin:0;min-width:200px}.chart-header>div{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.chart-header input[type=date],.chart-header select{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:9999px;color:#0f172a;cursor:pointer;font-size:.875rem;padding:.45rem 1rem;transition:all .2s ease}.chart-header input[type=date]:hover,.chart-header select:hover{background-color:#e2e8f0;border-color:#94a3b8}@media (max-width:768px){.chart-header{align-items:flex-start;flex-direction:row}.chart-header h2{font-size:1rem}.chart-header>div{gap:8px;justify-content:flex-end;width:100%}.chart-header input[type=date],.chart-header select{font-size:.8rem;padding:.4rem .9rem}}@media (max-width:480px){.chart-header input[type=date],.chart-header select{font-size:.75rem;padding:.4rem .8rem}}