*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden}.app-container{flex-direction:column;width:100vw;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;display:flex}.header{color:#fff;z-index:1000;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:1rem 2rem;box-shadow:0 2px 8px #0000001a}.header-row{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem;display:flex}.header h1{margin:0;font-size:1.8rem;font-weight:600}.train-search{align-items:center;gap:4px;display:flex;position:relative}.train-search-input{color:#fff;background:#fff3;border:none;border-radius:6px;outline:none;width:140px;padding:6px 10px;font-size:.85rem;transition:background .2s}.train-search-input::placeholder{color:#fff9}.train-search-input:focus{background:#ffffff4d}.train-search-btn{cursor:pointer;background:#fff3;border:none;border-radius:6px;padding:5px 8px;font-size:.85rem;transition:background .2s}.train-search-btn:hover{background:#ffffff59}.train-search-error{color:#fff;white-space:nowrap;background:#f44;border-radius:4px;margin-top:4px;padding:3px 8px;font-size:.75rem;position:absolute;top:100%;left:0}.status{opacity:.95;align-items:center;gap:.5rem;font-size:.9rem;display:flex}.status-indicator{background-color:#f44;border-radius:50%;width:10px;height:10px;animation:2s infinite pulse}.status-indicator.connected{background-color:#4f4}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.divider{color:#ffffff80}.map-container{flex:1;position:relative;overflow:hidden}.train-marker{cursor:pointer;filter:drop-shadow(0 2px 4px #0000004d);font-size:22px;line-height:1;transition:filter .2s;position:relative}.train-marker:hover{filter:drop-shadow(0 2px 8px #00000080)}.train-delay-dot{pointer-events:none;border:1px solid #fffc;border-radius:50%;width:10px;height:10px;position:absolute;top:-2px;right:-2px}.train-arrow-orbit{pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0}.train-arrow{border-bottom:8px solid #1e1e1ed9;border-left:5px solid #0000;border-right:5px solid #0000;width:0;height:0;position:absolute;top:-6px;left:50%;transform:translate(-50%)}.info-window{max-width:300px;padding:.5rem}.info-window h3{color:#333;border-bottom:2px solid #667eea;margin:0 0 .75rem;padding-bottom:.5rem;font-size:1.1rem}.info-subtitle{color:#777;margin:-.4rem 0 .6rem;font-size:.85rem}.arrival-time{color:#667eea;font-weight:600}.info-details p{color:#555;margin:.4rem 0;font-size:.85rem}.info-details strong{color:#333;font-weight:600}.loading{color:#667eea;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;display:flex}.gm-ui-hover-effect{opacity:1!important}.gm-ui-hover-effect>span{background-color:#333!important}.gm-style-iw button[aria-label=Close]{background-color:#f5f5f5!important;border-radius:50%!important;top:8px!important;right:8px!important}.gm-style-iw button[aria-label=Close]>span{background-color:#333!important}.delay-status{border-radius:4px;padding:4px 8px;font-weight:500;margin-top:8px!important}.delay-status.on-time{color:#2e7d32;background-color:#e8f5e9}.delay-status.slight-delay{color:#f9a825;background-color:#fffde7}.delay-status.delayed{color:#c62828;background-color:#ffebee}.delay-status.early{color:#1565c0;background-color:#e3f2fd}.station-marker{cursor:pointer;filter:drop-shadow(0 1px 2px #0000004d);opacity:.85;font-size:18px;transition:transform .3s}.station-marker:hover{opacity:1;transform:scale(1.3)}.station-info{max-width:380px}.station-info h3{border-bottom-color:#f57c00!important}.station-badges{flex-wrap:wrap;gap:.5rem;margin:.5rem 0;display:flex}.badge{text-transform:uppercase;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.badge.cercanias{color:#1565c0;background-color:#e3f2fd}.badge.feve{color:#e65100;background-color:#fff3e0}.badge.accessible{color:#2e7d32;background-color:#e8f5e9}.badge.plate{color:#555;letter-spacing:.04em;background-color:#f5f5f5;font-family:monospace}.cluster-marker{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:2px solid #ffffff8c;border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex;box-shadow:0 2px 8px #00000059}.follow-btn{color:#667eea;cursor:pointer;background:#fff;border:1px solid #667eea;border-radius:4px;justify-content:center;align-items:center;gap:4px;width:100%;margin-top:10px;padding:4px 10px;font-size:.8rem;transition:all .2s;display:inline-flex}.follow-btn:hover,.follow-btn.active{color:#fff;background:#667eea}.coords{color:#888!important;margin-top:.5rem!important;font-size:.8rem!important}.layers-panel{z-index:9999;flex-direction:column;align-items:flex-end;display:flex;position:absolute;top:10px;right:10px}.layers-toggle{cursor:pointer;background:#fff;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;transition:all .2s;display:flex;box-shadow:0 2px 6px #0003}.layers-toggle:hover{background:#f5f5f5;transform:scale(1.05)}.layers-panel.open .layers-toggle{border-radius:8px 8px 0 0}.layers-content{background:#fff;border-radius:0 0 8px 8px;min-width:180px;padding:12px 16px;animation:.2s slideDown;box-shadow:0 2px 6px #0003}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.layers-content h4{color:#333;border-bottom:2px solid #667eea;margin:0 0 12px;padding-bottom:8px;font-size:.9rem;font-weight:600}.layer-option{cursor:pointer;border-radius:4px;align-items:center;gap:8px;padding:8px 4px;transition:background .2s;display:flex}.layer-option:hover{background:#f5f5f5}.layer-option input[type=checkbox]{cursor:pointer;accent-color:#667eea;width:18px;height:18px}.layer-icon{font-size:18px}.layer-option span:last-child{color:#333;font-size:.9rem}.layers-section-title{text-transform:uppercase;letter-spacing:.06em;color:#999;margin:10px 0 4px;font-size:.7rem;font-weight:700}.layers-section-title:first-of-type{margin-top:0}.alert-banner{z-index:999;background:#fff8e1;border-bottom:2px solid #ffc107;flex-shrink:0}.alert-banner-toggle{cursor:pointer;color:#7d5a00;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:.5rem;width:100%;padding:.45rem 2rem;font-size:.875rem;font-weight:600;display:flex}.alert-banner-toggle:hover{background:#fff3cd}.alert-list{flex-direction:column;gap:.4rem;max-height:180px;padding:0 2rem .75rem;display:flex;overflow-y:auto}.alert-item{background:#fff;border-left:3px solid #ffc107;border-radius:4px;padding:.5rem .75rem;font-size:.82rem}.alert-item-header{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.alert-item-header strong{color:#333}.alert-line-badge{color:#333;background:#ffc107;border-radius:10px;padding:1px 6px;font-size:.72rem;font-weight:700;display:inline-block}.alert-item p{color:#666;margin-top:.2rem;font-size:.8rem}.my-location-btn{cursor:pointer;background:#fff;border:none;border-radius:2px;justify-content:center;align-items:center;width:40px;height:40px;margin:0 10px 10px 0;padding:0;transition:background .15s;display:flex;box-shadow:0 1px 4px #0000004d}.my-location-btn:hover{background:#f5f5f5}.train-spec-card{background:#f8f9ff;border-left:3px solid #667eea;border-radius:6px;margin-top:10px;padding:8px 10px;font-size:.82rem}.train-spec-card p{color:#555;margin:.2rem 0}.train-spec-card strong{color:#333;font-weight:600}.spec-title{color:#333!important;margin-bottom:.35rem!important;font-size:.85rem!important;font-weight:700!important}.delay-dot{border-radius:50%;flex-shrink:0;display:inline-block;width:10px!important;height:10px!important}.route-timeline{background:#f8f9ff;border-left:3px solid #667eea;border-radius:6px;margin-top:10px;padding:8px 10px;font-size:.82rem}.route-timeline-title{color:#333;margin-bottom:6px;font-size:.85rem;font-weight:700}.route-stops-list{max-height:180px;margin:0;padding:0;list-style:none;overflow-y:auto}.route-stop{align-items:center;gap:6px;padding:2px 0;font-size:.8rem;display:flex}.route-stop-dot{border:2px solid;border-radius:50%;flex-shrink:0;width:8px;height:8px}.route-stop--completed{color:#999}.route-stop--completed .route-stop-dot{background:#999;border-color:#999}.route-stop--current{color:#1a73e8;font-weight:600}.route-stop--current .route-stop-dot{background:#1a73e8;border-color:#1a73e8;width:10px;height:10px}.route-stop--pending{color:#444}.route-stop--pending .route-stop-dot{background:0 0;border-color:#667eea}.route-stop-name{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.route-stop-time{font-variant-numeric:tabular-nums;color:inherit;flex-shrink:0}.station-departures{background:#fff8f0;border-left:3px solid #f57c00;border-radius:6px;margin-top:10px;padding:8px 10px;font-size:.82rem}.station-departures-title{color:#333;margin-bottom:6px;font-size:.85rem;font-weight:700}.departures-list{max-height:160px;margin:0;padding:0;list-style:none;overflow-y:auto}.departure-row{border-bottom:1px solid #f0e0cc;align-items:center;gap:5px;padding:3px 0;font-size:.8rem;display:flex}.departure-row:last-child{border-bottom:none}.departure-delay-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.departure-icon{flex-shrink:0}.departure-label{color:#333;flex-shrink:0;min-width:45px;font-weight:600}.departure-dest{color:#666;text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.departure-dest--origin{font-style:italic}.departure-row--arrival .departure-time{color:#888}.departure-time{font-variant-numeric:tabular-nums;color:#333;text-align:right;flex-shrink:0;min-width:38px;font-weight:600}.departures-note{color:#999;margin-top:4px;font-size:.72rem;font-style:italic}
