*{margin:0;padding:0;box-sizing:border-box}html{color-scheme:dark;overflow-x:hidden;width:100%}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:#0a0a0a;color:#e0e0e0;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%}button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}input{font-family:inherit}:root{--bg: #0a0a0a;--surface: #141414;--surface-hover: #1c1c1c;--border: #222;--primary: #f5a623;--primary-dim: #c4851a;--primary-rgb: 245, 166, 35;--text: #e0e0e0;--text-dim: #888;--danger: #ff6b6b;--success: #4caf50;--radius: 16px;--radius-sm: 10px;--palette-transition: 3s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{transition:background-color var(--palette-transition),border-color var(--palette-transition),color var(--palette-transition),box-shadow var(--palette-transition),fill var(--palette-transition)}[style*=transform],[style*=opacity]{transition:background-color var(--palette-transition),border-color var(--palette-transition),color var(--palette-transition),box-shadow var(--palette-transition),fill var(--palette-transition)}::selection{background:rgba(var(--primary-rgb),.35);color:#fff}button:focus-visible,a:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}.app{position:relative;min-height:100dvh;display:flex;flex-direction:column;align-items:center;padding:1rem;padding-top:max(2.5rem,calc(env(safe-area-inset-top,0px) + 1.5rem));padding-bottom:calc(4rem + env(safe-area-inset-bottom,0px));overflow:hidden;overflow-x:hidden;outline:none;width:100%;max-width:100vw}.app:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 600px 400px at 20% 30%,rgba(var(--primary-rgb),.07),transparent),radial-gradient(ellipse 500px 350px at 80% 70%,rgba(var(--primary-rgb),.04),transparent);animation:bgDrift 12s ease-in-out infinite alternate;overflow:hidden}@keyframes bgDrift{0%{transform:translate(0) scale(1.1)}50%{transform:translate(0) scale(1.12)}to{transform:translate(0) scale(1.1)}}.paw-print{position:fixed;font-size:1.4rem;pointer-events:none;z-index:0;filter:grayscale(.5)}.header{text-align:center;margin:.5rem 0 1rem;z-index:1}.cat-logo{font-size:3rem;line-height:1;margin-bottom:.25rem;display:inline-block;transform-origin:center bottom}.cat-row{display:flex;align-items:flex-end;justify-content:center;gap:0;margin-bottom:.25rem}.cig-emoji{font-size:2rem;line-height:1;display:inline-block;transform-origin:right center;margin-bottom:.2rem;margin-left:-.9rem;transform:scaleX(-1);filter:drop-shadow(0 0 4px rgba(var(--primary-rgb),.3))}.app-title{font-size:2.4rem;font-weight:800;letter-spacing:-1px;color:var(--primary);margin:0}.app-subtitle{font-size:.95rem;margin-top:.25rem}.search-section{width:100%;max-width:420px;display:flex;flex-direction:column;gap:.5rem;z-index:1}.inputs-row{display:flex;align-items:center;gap:.3rem}.input-col{flex:1;min-width:0}.station-input-wrap{display:flex;gap:.3rem}.station-input{flex:1;min-width:0;padding:.6rem .7rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.85rem;outline:none;transition:border-color .2s,box-shadow .2s}.station-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.15)}.station-input:focus-visible{outline:none}.station-input::placeholder{color:#555}.geo-btn{padding:.4rem .55rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;cursor:pointer;transition:background .2s,border-color .2s;flex-shrink:0}.geo-btn:hover{background:var(--surface-hover);border-color:var(--primary)}.geo-btn:active{transform:scale(.95)}.swap-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:50%;color:var(--primary);font-size:1rem;cursor:pointer;transition:background .2s;flex-shrink:0}.swap-btn:hover{background:var(--surface-hover)}.bottom-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.modo-toggle{display:flex;width:100%;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.modo-btn{flex:1;padding:.45rem .5rem;font-size:.78rem;font-weight:600;background:var(--surface);color:var(--text-dim);border:none;cursor:pointer;transition:background .2s,color .2s}.modo-btn:first-child{border-right:1px solid var(--border)}.modo-btn.active{background:rgba(var(--primary-rgb),.15);color:var(--primary)}.modo-btn:hover:not(.active){background:var(--surface-hover)}.hora-objetivo-wrap{width:100%}.hora-objetivo-input{width:100%;padding:.5rem .75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:.9rem;font-weight:600;outline:none;transition:border-color .2s;color-scheme:dark}.hora-objetivo-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.15)}.hora-objetivo-input:focus-visible{outline:none}.ventana-row{width:100%;display:flex;flex-direction:column;gap:.25rem}.ventana-action-row{display:flex;align-items:center;gap:.5rem}.ventana-hint{font-size:.7rem;color:var(--text-dim);letter-spacing:.3px;text-transform:uppercase}.ventana-inline{display:flex;align-items:center;gap:.4rem;min-width:0;flex:1}.ventana-label{font-size:.75rem;color:var(--primary);white-space:nowrap;min-width:38px;font-weight:600;font-variant-numeric:tabular-nums}.ventana-slider{-webkit-appearance:none;flex:1;height:4px;background:var(--border);border-radius:2px;outline:none;min-width:0}.ventana-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 0 6px rgba(var(--primary-rgb),.4)}.ventana-slider::-moz-range-thumb{width:16px;height:16px;background:var(--primary);border-radius:50%;cursor:pointer;border:none}.search-btn-wrap{cursor:pointer;font-size:.85rem;font-weight:600;letter-spacing:.3px;flex-shrink:0;animation:glowPulse 2.5s ease-in-out infinite}.search-btn-wrap:disabled{opacity:.6;cursor:not-allowed;animation:none}@keyframes glowPulse{0%,to{filter:drop-shadow(0 0 4px rgba(var(--primary-rgb),.2))}50%{filter:drop-shadow(0 0 16px rgba(var(--primary-rgb),.5))}}.search-btn-wrap .inner-content{padding:8px 16px;background:var(--surface);border:1px solid var(--border)}.search-btn-wrap:hover .inner-content{background:var(--surface-hover);border-color:var(--primary-dim)}.error-msg{max-width:420px;width:100%;padding:.75rem 1rem;margin-top:.8rem;background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);border-radius:var(--radius-sm);color:var(--danger);font-size:.9rem;text-align:center;z-index:1}.results-section{width:100%;max-width:420px;margin-top:1.2rem;z-index:1}.route-summary{display:flex;align-items:center;justify-content:center;gap:.4rem;flex-wrap:wrap;padding:.65rem .8rem;background:#14141499;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(var(--primary-rgb),.15);border-radius:var(--radius);margin-bottom:.8rem;box-shadow:0 4px 20px #0000004d}.route-station{font-weight:700;font-size:.95rem;color:var(--primary)}.route-arrow{color:var(--text-dim);font-size:1rem}.meta-chip{font-size:.75rem;color:var(--text-dim);background:#ffffff0d;padding:.15rem .5rem;border-radius:20px}.walk-info{font-size:.82rem;color:var(--text-dim);padding:.6rem .8rem;background:rgba(var(--primary-rgb),.06);border-left:3px solid var(--primary-dim);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:.5rem}.walk-origin{display:flex;flex-direction:column;gap:.25rem}.walk-step{color:var(--text-dim)}.walk-arrival{color:var(--primary);font-weight:600;font-size:.85rem}.walk-dest{margin-top:.5rem}.station-link{color:var(--primary);text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px;transition:color .2s}.station-link:hover{color:#ffc966}.trains-list{display:flex;flex-direction:column;gap:.5rem}.train-card{background:#1414148c;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:.85rem 1rem;transition:transform .25s ease,border-color .25s,box-shadow .25s;box-shadow:0 2px 8px #0003}.train-card:hover{border-color:rgba(var(--primary-rgb),.3);transform:translateY(-2px);box-shadow:0 8px 24px #00000059,0 0 0 1px rgba(var(--primary-rgb),.12)}.train-times{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.train-departure{font-size:1.3rem;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums}.train-arrow{color:var(--text-dim)}.train-arrival{font-size:1.1rem;font-weight:600;color:var(--text-dim);font-variant-numeric:tabular-nums}.train-info{display:flex;align-items:center;gap:.5rem}.linea-badge{display:inline-flex;align-items:center;justify-content:center;padding:.15rem .5rem;border-radius:6px;font-size:.75rem;font-weight:700;color:#fff;letter-spacing:.5px}.train-dest{font-size:.82rem;color:var(--text-dim)}.train-final-arrival{font-size:.78rem;color:var(--text-dim);margin-top:.35rem;display:flex;flex-wrap:wrap;align-items:center;gap:0}.train-final-arrival .final-time{color:var(--primary);font-weight:600}.transfer-station{color:var(--text)!important;font-size:.85rem}.transbordo-chip{background:rgba(var(--primary-rgb),.15);color:var(--primary);font-weight:600}.route-transfer{display:inline-flex;align-items:center;gap:.4rem}.transbordo-section{margin:.6rem 0 .4rem;padding:.6rem .75rem;background:rgba(var(--primary-rgb),.06);border-radius:var(--radius-sm);border:1px dashed rgba(var(--primary-rgb),.2)}.transbordo-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.45rem;flex-wrap:wrap}.transbordo-icon{font-size:.9rem}.transbordo-label{font-size:.78rem;color:var(--text-dim)}.transbordo-label strong{color:var(--primary)}.transbordo-wait{font-size:.7rem;color:var(--text-dim);background:#ffffff0f;padding:.1rem .4rem;border-radius:10px;margin-left:auto}.tramo2-times{margin-bottom:.3rem}.tramo2-times .train-departure{font-size:1.05rem;font-weight:700}.tramo2-times .train-arrival{font-size:.95rem}.no-trains{text-align:center;padding:2rem;color:var(--text-dim)}.no-trains-cat{font-size:2.5rem}.time-info{text-align:center;font-size:.75rem;color:#555;margin-top:.8rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:380px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:1rem;color:var(--text)}.modal-close{background:none;border:none;color:var(--text-dim);font-size:1.1rem;cursor:pointer;padding:.2rem .4rem;border-radius:6px;transition:background .2s}.modal-close:hover{background:var(--surface-hover);color:var(--text)}.modal-body{padding:.5rem;overflow-y:auto;flex:1}.modal-empty{text-align:center;color:var(--text-dim);font-size:.85rem;padding:1rem}.saved-dest-item{display:flex;align-items:center;gap:.3rem;margin-bottom:.3rem}.saved-dest-btn{flex:1;display:flex;flex-direction:column;gap:.1rem;padding:.55rem .7rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:border-color .2s,background .2s}.saved-dest-btn:hover{border-color:var(--primary-dim);background:rgba(var(--primary-rgb),.06)}.saved-dest-name{font-size:.88rem;font-weight:600;color:var(--text)}.saved-dest-coords{font-size:.72rem;color:var(--text-dim);font-variant-numeric:tabular-nums}.saved-dest-delete{background:none;border:none;cursor:pointer;font-size:.9rem;padding:.4rem;border-radius:6px;transition:background .2s;flex-shrink:0}.saved-dest-delete:hover{background:#ff6b6b26}.modal-add{padding:.7rem 1rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.4rem}.modal-add-title{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px;margin:0}.modal-input{width:100%;padding:.45rem .65rem;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.85rem;outline:none;transition:border-color .2s;box-sizing:border-box}.modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb),.12)}.modal-input:focus-visible{outline:none}.modal-error{font-size:.75rem;color:var(--danger);margin:0}.modal-add-btn{padding:.5rem;background:rgba(var(--primary-rgb),.12);border:1px solid var(--primary-dim);border-radius:8px;color:var(--primary);font-weight:600;font-size:.82rem;cursor:pointer;transition:background .2s}.modal-add-btn:hover{background:rgba(var(--primary-rgb),.22)}.splash{position:fixed;inset:0;z-index:999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.3rem;overflow:hidden;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}.splash-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--primary);pointer-events:none}.splash-cat{font-size:4rem;line-height:1;display:inline-block;transform-origin:center bottom;filter:drop-shadow(0 0 20px rgba(var(--primary-rgb),.5))}.splash-paws{display:flex;gap:1rem;font-size:1.4rem;margin-top:-.2rem}.splash-title{font-family:SF Pro Display,-apple-system,sans-serif;font-size:2rem;font-weight:700;background:linear-gradient(135deg,var(--primary),#ff8c42);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:.3rem 0 0}.splash-sub{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-dim);margin:0;letter-spacing:1px;text-decoration:none;transition:color .2s}.splash-sub:hover{color:var(--primary)}.linkedin-link{display:flex;align-items:center;justify-content:center;gap:.35rem;text-decoration:none;color:#888;font-size:.82rem;letter-spacing:.3px;transition:color .2s;width:100%}.linkedin-link:hover{color:var(--primary)}.linkedin-icon{width:.9em;height:.9em;flex-shrink:0}.footer{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:center;align-items:center;padding:.6rem;padding-bottom:calc(.6rem + env(safe-area-inset-bottom,0px));background:linear-gradient(transparent,var(--bg) 40%);font-size:.8rem;z-index:10;pointer-events:none}.footer-link{display:inline;text-decoration:none;color:#444;transition:color .2s;pointer-events:auto}.footer-link:hover{color:var(--primary)}.footer-sep{color:#444;margin:0 .3rem;pointer-events:none}.shiny-text{display:inline-block}.star-border-container{display:inline-block;position:relative;border-radius:20px;overflow:hidden}.border-gradient-bottom{position:absolute;width:300%;height:50%;opacity:.7;bottom:-12px;right:-250%;border-radius:50%;animation:star-movement-bottom linear infinite alternate;z-index:0}.border-gradient-top{position:absolute;opacity:.7;width:300%;height:50%;top:-12px;left:-250%;border-radius:50%;animation:star-movement-top linear infinite alternate;z-index:0}.inner-content{position:relative;background:var(--surface, #1a1a1a);color:var(--text, #e0e0e0);font-size:16px;text-align:center;padding:16px 26px;border-radius:20px;z-index:1}@keyframes star-movement-bottom{0%{transform:translate(0);opacity:1}to{transform:translate(-100%);opacity:0}}@keyframes star-movement-top{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}
