:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #dbeafe;--success: #16a34a;--success-light: #dcfce7;--warning: #ea580c;--warning-light: #fff7ed;--danger: #dc2626;--danger-light: #fef2f2;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 8px;--radius-lg: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 25px rgba(0,0,0,.1);--transition: .2s ease;--safe-bottom: env(safe-area-inset-bottom, 0px);--bottom-nav-h: 60px}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--gray-900);background:var(--gray-50);line-height:1.5;overflow-x:hidden}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}code{background:var(--gray-100);padding:.1em .35em;border-radius:4px;font-size:.85em}.app-layout{display:flex;min-height:100vh;min-height:100dvh}.sidebar{width:250px;background:var(--gray-900);color:#fff;display:flex;flex-direction:column;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-brand{display:flex;align-items:center;gap:.65rem;padding:1rem 1.25rem 1.25rem;border-bottom:1px solid var(--gray-700)}.sidebar-brand h1{font-size:.95rem;font-weight:700;line-height:1.2}.sidebar-brand small{display:block;font-weight:400;font-size:.7rem;color:var(--gray-500);margin-top:1px}.sidebar nav{flex:1;padding-top:.5rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar nav a{display:flex;align-items:center;gap:.65rem;padding:.6rem 1.25rem;color:var(--gray-300);font-size:.88rem;transition:background var(--transition),color var(--transition);border-left:3px solid transparent}.sidebar nav a:hover{background:#ffffff0f;color:#fff;text-decoration:none}.sidebar nav a.active{background:#2563eb26;color:#fff;border-left-color:var(--primary);text-decoration:none}.nav-divider{font-size:.65rem;font-weight:700;color:var(--gray-500);padding:1rem 1.25rem .35rem;text-transform:uppercase;letter-spacing:.08em}.sidebar-footer{border-top:1px solid var(--gray-700);padding:.75rem 1.25rem}.sidebar-user{display:flex;align-items:center;gap:.65rem}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.sidebar-login-link{display:flex;align-items:center;gap:.5rem;color:var(--gray-400);text-decoration:none;font-size:.85rem;padding:.25rem 0;transition:color .2s}.sidebar-login-link:hover{color:var(--gray-100)}.mobile-menu-overlay,.mobile-topbar,.bottom-nav{display:none}.main-content{flex:1;padding:1.5rem 2rem;overflow-x:hidden;min-width:0;margin-left:250px}.card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.25rem;margin-bottom:1rem}.card h2{font-size:1.1rem;margin-bottom:.75rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius);border:1px solid transparent;font-size:.875rem;cursor:pointer;font-weight:500;transition:all var(--transition);text-decoration:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn:hover{text-decoration:none}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-outline{background:#fff;border-color:var(--gray-300);color:var(--gray-700)}.btn-outline:hover{background:var(--gray-100)}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.3rem;color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.55rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:16px;outline:none;transition:border-color var(--transition),box-shadow var(--transition);-webkit-appearance:none;appearance:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--gray-200)}th{background:var(--gray-50);font-weight:600;font-size:.78rem;text-transform:uppercase;color:var(--gray-500);letter-spacing:.03em;white-space:nowrap}tr:hover{background:var(--gray-50)}.badge{display:inline-flex;align-items:center;gap:4px;padding:.18rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase;white-space:nowrap}.badge-draft{background:var(--gray-200);color:var(--gray-700)}.badge-pending{background:#fef3c7;color:#92400e}.badge-approved{background:#dcfce7;color:#166534}.badge-rejected{background:#fecaca;color:#991b1b}.badge-rolled_back{background:#e0e7ff;color:#3730a3}.badge-bus{background:#dbeafe;color:#1e40af}.badge-trolleybus{background:#fce7f3;color:#9d174d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem;margin-bottom:1.25rem}.stat-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:.85rem;text-align:center;transition:box-shadow var(--transition),transform var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card.clickable{cursor:pointer;-webkit-tap-highlight-color:transparent}.stat-card.clickable:hover{transform:translateY(-1px)}.stat-card.clickable:active{transform:scale(.97)}.stat-card-active{box-shadow:0 0 0 2px var(--primary),var(--shadow-md)}.stat-card .stat-icon{margin-bottom:.25rem}.stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--gray-900);line-height:1.2}.stat-card .stat-label{font-size:.7rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}.map-container{height:500px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);margin-bottom:1rem}.map-container .leaflet-container{height:100%;width:100%}.tabs{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{display:flex;align-items:center;gap:6px;padding:.65rem 1rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:.85rem;font-weight:500;color:var(--gray-500);cursor:pointer;transition:all var(--transition);white-space:nowrap;-webkit-tap-highlight-color:transparent}.tab:hover{color:var(--gray-900);background:var(--gray-50)}.tab-active{color:var(--primary);border-bottom-color:var(--primary)}.route-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.route-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1rem 1.15rem;border-top:3px solid var(--primary);transition:box-shadow var(--transition),transform var(--transition);text-decoration:none;color:inherit;display:block;-webkit-tap-highlight-color:transparent}.route-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}.route-card:active{transform:scale(.98)}.route-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.route-number{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:32px;padding:0 .5rem;border-radius:6px;background:var(--primary);color:#fff;font-weight:700;font-size:1rem}.route-number-sm{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:24px;padding:0 .4rem;border-radius:5px;background:var(--primary);color:#fff;font-weight:700;font-size:.8rem}.route-number-lg{display:inline-flex;align-items:center;justify-content:center;min-width:52px;height:40px;padding:0 .6rem;border-radius:8px;background:var(--primary);color:#fff;font-weight:700;font-size:1.2rem}.route-card-name{font-size:.88rem;color:var(--gray-700);line-height:1.3;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.route-card-footer{display:flex;align-items:center;justify-content:space-between}.route-detail-header{background:#fff;border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow);border-left:4px solid var(--primary)}.route-meta{display:flex;gap:1.25rem;margin-top:.75rem;font-size:.85rem;color:var(--gray-500);flex-wrap:wrap}.route-meta span{display:flex;align-items:center;gap:4px}.back-link{display:inline-flex;align-items:center;gap:4px;color:var(--gray-500);font-size:.85rem;margin-bottom:.75rem;transition:color var(--transition);-webkit-tap-highlight-color:transparent}.stop-seq{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--gray-100);font-size:.75rem;font-weight:600;color:var(--gray-700)}.vehicle-list-item{padding:.55rem .75rem;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background var(--transition);-webkit-tap-highlight-color:transparent}.vehicle-list-item:hover{background:var(--gray-50)}.vehicle-list-item:active{background:var(--gray-100)}.vehicle-list-item-active{background:var(--primary-light)!important}.vehicle-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.vehicle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.vehicle-card{background:var(--gray-50);border-radius:var(--radius);padding:.75rem;border:1px solid var(--gray-200)}.vehicle-card-details{display:flex;flex-direction:column;gap:4px;font-size:.8rem;color:var(--gray-500)}.vehicle-card-details span{display:flex;align-items:center;gap:6px}.live-dot{width:8px;height:8px;border-radius:50%;background:#16a34a;display:inline-block;animation:pulse 2s infinite}.live-dot-sm{width:6px;height:6px;border-radius:50%;background:#16a34a;display:inline-block;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1;box-shadow:0 0 #16a34a80}50%{opacity:.8;box-shadow:0 0 0 4px #16a34a00}to{opacity:1;box-shadow:0 0 #16a34a00}}.live-vehicle-badge{display:inline-flex;align-items:center;gap:5px;background:var(--success-light);color:var(--success);padding:.15rem .5rem;border-radius:999px;font-size:.75rem;font-weight:600}.proposals-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.proposals-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.proposal-card-list{display:flex;flex-direction:column;gap:.5rem}.proposal-card{display:flex;align-items:stretch;gap:.75rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:1rem;text-decoration:none;color:inherit;transition:border-color var(--transition),box-shadow var(--transition);-webkit-tap-highlight-color:transparent}.proposal-card:hover{border-color:var(--primary);box-shadow:0 2px 8px #2563eb14;text-decoration:none}.proposal-vote-col{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:40px}.vote-btn{display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--gray-200);border-radius:var(--radius);width:36px;height:32px;cursor:pointer;color:var(--gray-400);transition:all var(--transition);-webkit-tap-highlight-color:transparent}.vote-btn:hover,.vote-btn:active{background:var(--gray-50)}.vote-btn.vote-up:hover,.vote-btn.vote-up.active{color:#16a34a;border-color:#16a34a;background:#16a34a0f}.vote-btn.vote-down:hover,.vote-btn.vote-down.active{color:#dc2626;border-color:#dc2626;background:#dc26260f}.vote-count{font-weight:700;font-size:.95rem;color:var(--gray-500)}.vote-count.positive{color:#16a34a}.vote-count.negative{color:#dc2626}.vote-count-large{font-weight:700;font-size:1.5rem;color:var(--gray-500)}.vote-count-large.positive{color:#16a34a}.vote-count-large.negative{color:#dc2626}.proposal-card-content{flex:1;min-width:0}.proposal-card-top{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.35rem}.proposal-card-title{font-size:1rem;font-weight:600;margin:0 0 .3rem;color:var(--gray-800)}.proposal-card-desc{font-size:.85rem;color:var(--gray-500);margin:0 0 .4rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.proposal-card-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.75rem;color:var(--gray-500);align-items:center}.proposal-card-meta span{display:flex;align-items:center;gap:3px}.proposal-card-arrow{color:var(--gray-300);flex-shrink:0;align-self:center}.badge-type{background:var(--gray-100);color:var(--gray-600)}.back-link{display:inline-flex;align-items:center;gap:4px;color:var(--gray-500);font-size:.85rem;text-decoration:none;margin-bottom:.75rem}.back-link:hover{color:var(--primary);text-decoration:none}.proposal-detail-header{display:flex;align-items:flex-start;gap:1.25rem;margin-bottom:1rem}.proposal-detail-vote-box{display:flex;flex-direction:column;align-items:center;gap:4px;padding:.5rem;background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--gray-200)}.proposal-detail-vote-box .vote-btn{width:44px;height:38px}.proposal-detail-info{flex:1;min-width:0}.proposal-detail-badges{display:flex;gap:.4rem;margin-bottom:.4rem}.proposal-detail-info h1{font-size:1.35rem;margin:0 0 .4rem}.proposal-detail-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:var(--gray-500)}.proposal-detail-meta span{display:flex;align-items:center;gap:4px}.share-btn{align-self:flex-start;flex-shrink:0}.vote-progress-card{margin-bottom:1rem}.vote-progress-header{display:flex;justify-content:space-between;font-size:.8rem;color:var(--gray-500);margin-bottom:.4rem}.vote-progress-header span{display:flex;align-items:center;gap:4px}.vote-progress-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--gray-100)}.vote-progress-up{background:#16a34a}.vote-progress-down{background:#dc2626}.vote-progress-hint{font-size:.75rem;color:var(--gray-400);margin-top:.4rem;text-align:center}.comment-form{margin-bottom:1rem}.comment-form-row{margin-bottom:.5rem}.comment-author-input{width:100%;max-width:250px;padding:.5rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem;outline:none}.comment-author-input:focus{border-color:var(--primary)}.comment-textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:.9rem;font-family:inherit;resize:vertical;outline:none}.comment-textarea:focus{border-color:var(--primary)}.comments-list{margin-top:1rem}.comment{border-bottom:1px solid var(--gray-100);padding:.65rem 0}.comment-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.comment-date{font-size:.75rem;color:var(--gray-400)}.comment-text{font-size:.9rem;margin:0;line-height:1.5}.new-proposal-grid{grid-template-columns:1fr 1fr!important}.new-proposal-map{height:500px!important}.new-proposal-actions{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.proposal-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.proposal-type-btn{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:.65rem .75rem;border:2px solid var(--gray-200);border-radius:var(--radius);background:#fff;cursor:pointer;text-align:left;transition:all var(--transition);-webkit-tap-highlight-color:transparent}.proposal-type-btn strong{font-size:.85rem;color:var(--gray-800)}.proposal-type-btn small{font-size:.7rem;color:var(--gray-500)}.proposal-type-btn:hover{border-color:var(--primary)}.proposal-type-btn.active{border-color:var(--primary);background:#2563eb0a}.dash-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.dash-header h1{display:flex;align-items:center;gap:8px;margin:0}.dash-subtitle{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--gray-500);margin-top:4px}.dash-sep{margin:0 2px}.dash-map-card{padding:0!important;overflow:hidden}.dash-map-header{padding:.75rem 1.25rem;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;justify-content:space-between}.dash-map-header h2{margin:0;display:flex;align-items:center;gap:6px}.dash-map-container{border-radius:0!important;box-shadow:none!important}.dash-actions-grid{display:none}.dash-action-card{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);color:var(--gray-700);font-weight:500;font-size:.95rem;text-decoration:none;transition:all var(--transition);-webkit-tap-highlight-color:transparent}.dash-action-card:hover{color:var(--primary);text-decoration:none;border-color:var(--primary)}.dash-action-card span{flex:1}.dash-action-card svg:last-child{color:var(--gray-400)}.dash-action-live{color:var(--primary);border-color:#2563eb4d;background:#2563eb0a}.dash-action-contribute{color:#059669;border-color:#0596694d;background:#0596690a}.dash-action-contribute svg:first-child{color:#059669}.dash-action-live svg:first-child{color:var(--primary)}.dash-proposal-list{display:flex;flex-direction:column;gap:0}.dash-proposal-item{display:flex;flex-direction:column;gap:4px;padding:.75rem 0;border-bottom:1px solid var(--gray-100);color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.dash-proposal-item:last-child{border-bottom:none}.dash-proposal-item:hover{text-decoration:none}.dash-proposal-title{font-weight:500;font-size:.9rem;color:var(--gray-800)}.dash-proposal-meta{display:flex;align-items:center;gap:.5rem;font-size:.75rem}.quick-links{display:flex;flex-direction:column;gap:0}.quick-link-item{display:flex;align-items:center;gap:.65rem;padding:.7rem 0;border-bottom:1px solid var(--gray-100);color:var(--gray-700);font-size:.9rem;transition:color var(--transition);-webkit-tap-highlight-color:transparent}.quick-link-item:last-child{border-bottom:none}.quick-link-item:hover{color:var(--primary);text-decoration:none}.quick-link-item span{flex:1}.stop-routes-list{display:flex;flex-direction:column;gap:0}.stop-route-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px solid var(--gray-100);color:inherit;transition:background var(--transition);-webkit-tap-highlight-color:transparent}.stop-route-item:last-child{border-bottom:none}.stop-route-item:hover{text-decoration:none;color:var(--primary)}.stop-route-name{flex:1;font-size:.8rem;color:var(--gray-700);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loading-spinner{display:flex;align-items:center;justify-content:center;height:200px}.spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.spin{animation:spin .7s linear infinite}.flex-between{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:.5rem}.text-muted{color:var(--gray-500);font-size:.85rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.clickable{cursor:pointer}.route-color-dot{display:inline-block;width:14px;height:14px;border-radius:50%;margin-right:6px;vertical-align:middle}.comment{border-bottom:1px solid var(--gray-200);padding:.5rem 0}.comment:last-child{border-bottom:none}.comment-author{font-weight:600;font-size:.85rem}.comment-date{font-size:.75rem;color:var(--gray-500);margin-left:.5rem}.comment-text{font-size:.9rem;margin-top:.2rem}.responsive-two-col{display:grid;grid-template-columns:2fr 1fr;gap:1rem}.responsive-sidebar-layout{display:flex;gap:1rem}.responsive-sidebar-layout>:first-child{flex:1;min-width:0}.responsive-sidebar-layout>.sidebar-panel{width:300px;flex-shrink:0}.search-bar{position:relative;margin-bottom:1rem}.search-bar input{width:100%;padding:.6rem .75rem .6rem 2.25rem;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:16px;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.search-bar .search-icon{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--gray-500);pointer-events:none}.filter-buttons{display:flex;gap:.35rem;flex-wrap:wrap;align-items:center}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .3s ease;width:280px;z-index:1000}.sidebar.sidebar-open{transform:translate(0)}.mobile-menu-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-menu-overlay.overlay-visible{opacity:1;pointer-events:auto}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;position:fixed;top:0;left:0;right:0;height:56px;background:var(--gray-900);color:#fff;padding:0 1rem;z-index:200;box-shadow:0 2px 8px #00000026}.mobile-topbar-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem}.hamburger-btn{background:none;border:none;color:#fff;padding:.5rem;cursor:pointer;border-radius:var(--radius);-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center}.hamburger-btn:active{background:#ffffff1a}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-h);padding-bottom:var(--safe-bottom);background:#fff;border-top:1px solid var(--gray-200);z-index:200;box-shadow:0 -2px 10px #0000000f}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:.35rem 0;color:var(--gray-500);font-size:.65rem;font-weight:500;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:color var(--transition);position:relative}.bottom-nav-item:hover{text-decoration:none}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-item.active:before{content:"";position:absolute;top:0;left:25%;right:25%;height:2px;background:var(--primary);border-radius:0 0 2px 2px}.main-content{margin-left:0;padding:.75rem;padding-top:calc(56px + .75rem);padding-bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + .75rem)}h1{font-size:1.2rem!important}.flex-between{flex-wrap:wrap;gap:.5rem}.card{padding:1rem;border-radius:var(--radius);margin-bottom:.75rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.stat-card{padding:.65rem}.stat-card .stat-value{font-size:1.25rem}.stat-card .stat-label{font-size:.65rem}.map-container{height:300px;border-radius:var(--radius)}.route-grid{grid-template-columns:1fr;gap:.5rem}.route-detail-header{padding:1rem}.route-meta{gap:.75rem;font-size:.8rem}.responsive-two-col{grid-template-columns:1fr}.responsive-sidebar-layout{flex-direction:column}.responsive-sidebar-layout>.sidebar-panel{width:100%}.tabs{scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:.55rem .75rem;font-size:.8rem}.vehicle-grid{grid-template-columns:1fr}.btn{padding:.55rem 1rem;font-size:.9rem;min-height:44px}.btn-sm{padding:.4rem .7rem;font-size:.8rem;min-height:36px}th,td{padding:.5rem;font-size:.8rem}th{font-size:.7rem}.hide-mobile{display:none!important}.filter-buttons{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:.25rem}.quick-link-item{padding:.85rem 0;font-size:.95rem}.form-row{flex-direction:column;gap:0}.search-bar{max-width:100%!important}.dash-header{flex-direction:column;align-items:stretch;gap:.5rem;margin-bottom:.75rem}.dash-header h1{font-size:1.15rem!important}.dash-contribute-btn{width:100%;justify-content:center;padding:.65rem 1rem;font-size:.95rem}.dash-subtitle{font-size:.8rem}.dash-map-card{margin-left:-.75rem;margin-right:-.75rem;border-radius:0!important;border-left:none;border-right:none}.dash-map-container{height:55vh!important;min-height:280px}.dash-map-header{padding:.6rem .75rem}.dash-map-header h2{font-size:.95rem}.dash-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin:.75rem 0}.dash-action-card{padding:.75rem;font-size:.85rem;gap:.5rem}.dash-action-card svg:last-child{display:none}.dash-proposal-item{padding:.65rem 0}.dash-proposal-title{font-size:.85rem}.proposals-header{flex-direction:column;align-items:stretch;gap:.5rem}.proposals-header .btn{width:100%;justify-content:center}.proposals-toolbar{flex-direction:column;align-items:stretch;gap:.5rem}.proposal-card{padding:.75rem;gap:.5rem}.proposal-vote-col{min-width:36px}.vote-btn{width:32px;height:28px}.vote-count{font-size:.85rem}.proposal-card-title{font-size:.9rem}.proposal-card-desc{font-size:.8rem;-webkit-line-clamp:1}.proposal-card-arrow{display:none}.proposal-detail-header{flex-direction:column;gap:.75rem}.proposal-detail-vote-box{flex-direction:row;gap:.75rem;width:100%;justify-content:center;padding:.75rem}.proposal-detail-info h1{font-size:1.1rem!important}.share-btn{align-self:stretch;width:100%;justify-content:center}.vote-progress-card{padding:.75rem!important}.comment-author-input{max-width:100%}.comment-textarea{font-size:16px}.new-proposal-grid{grid-template-columns:1fr!important}.new-proposal-map{height:300px!important}.new-proposal-actions{flex-direction:column}.new-proposal-actions .btn{width:100%;justify-content:center}.proposal-type-grid{grid-template-columns:1fr}}@media(min-width:769px)and (max-width:1024px){.sidebar{width:220px}.main-content{margin-left:220px;padding:1.25rem}.stats-grid{grid-template-columns:repeat(3,1fr)}.route-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.responsive-sidebar-layout>.sidebar-panel{width:250px}}@media(min-width:769px){.show-mobile-only{display:none!important}}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-900);padding:1rem}.login-card{background:var(--gray-800);border:1px solid var(--gray-700);border-radius:12px;padding:2rem;width:100%;max-width:380px;display:flex;flex-direction:column;gap:1rem}.login-card h2{text-align:center;color:var(--gray-100);margin:0 0 .5rem;font-size:1.25rem}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}
