*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}.skip-link{position:absolute;top:-100%;left:16px;z-index:9999;padding:8px 16px;background:var(--color-ocean);color:#fff;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;text-decoration:none}.skip-link:focus{top:8px}*:focus-visible{outline:2px solid var(--color-sky);outline-offset:2px}.app-main:focus{outline:none}.detail-page-title{font-size:1.2rem;font-weight:700}:root{--color-ocean: #0f4c75;--color-ocean-light: #1b6ca8;--color-ocean-dark: #0a3554;--color-sky: #3282b8;--color-foam: #bbe1fa;--color-sand: #f0f4f8;--color-white: #ffffff;--color-text: #1a2a3a;--color-text-light: #5a6a7a;--color-text-muted: #8a9aaa;--color-success: #2e7d32;--color-warning: #f57f17;--color-danger: #c62828;--color-border: #dde4ec;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 2px 8px rgba(0,0,0,.1);--shadow-lg: 0 4px 16px rgba(0,0,0,.12);--nav-height: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px)}[data-theme=dark]{--color-ocean: #1b6ca8;--color-ocean-light: #3a9ad9;--color-ocean-dark: #0d1b2a;--color-sky: #4a9fd4;--color-foam: #1a3a5c;--color-sand: #0f1923;--color-white: #162636;--color-text: #d8e4f0;--color-text-light: #8a9cb0;--color-text-muted: #5a6e82;--color-success: #4caf50;--color-warning: #ffb74d;--color-danger: #ef5350;--color-border: #243444;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 2px 8px rgba(0,0,0,.4);--shadow-lg: 0 4px 16px rgba(0,0,0,.5)}[data-theme=dark] .app-header,[data-theme=dark] .route-header,[data-theme=dark] .trip-planner-header{background:linear-gradient(135deg,#0d1b2a,#152a3e)}[data-theme=dark] .search-input{background:#ffffff14}[data-theme=dark] .search-input:focus{background:#ffffff24}[data-theme=dark] .schedule-time,[data-theme=dark] .fare-card{background:#1a2a3a}[data-theme=dark] .tag{background:#1a3a5c}[data-theme=dark] .tag.vehicle{background:#1b3326;color:#66bb6a}[data-theme=dark] .tag.walk-on{background:#1a2d44;color:#64b5f6}[data-theme=dark] .tag.seasonal{background:#3e2a10;color:#ffb74d}[data-theme=dark] .tag.first-come{background:#3e1a1a;color:#ef9a9a}[data-theme=dark] .trip-select{background:#ffffff14}[data-theme=dark] .alert-banner{background:#1a2a3a!important}[data-theme=dark] .filter-pill{background:#1a2a3a;border-color:#2a3a4a}[data-theme=dark] .wait-chip{background:#1a2a3a}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--color-sand);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased;overscroll-behavior:none}a{color:var(--color-ocean-light);text-decoration:none}a:hover{text-decoration:underline}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--color-ocean-dark),var(--color-ocean));color:var(--color-white);padding:12px 16px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}.app-header h1{font-size:1.15rem;font-weight:700;letter-spacing:-.01em}.app-header .subtitle{font-size:.72rem;opacity:.8;font-weight:400;letter-spacing:.03em;text-transform:uppercase}.app-main{flex:1;padding-bottom:calc(var(--nav-height) + var(--safe-bottom) + 8px)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--color-white);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-around;z-index:100;box-shadow:0 -2px 8px #0000000f}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;border:none;background:none;color:var(--color-text-muted);font-size:.65rem;font-weight:500;cursor:pointer;transition:color .15s;text-decoration:none;-webkit-tap-highlight-color:transparent}.nav-item.active{color:var(--color-ocean)}.nav-item svg{width:24px;height:24px}.card{background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:12px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-body{padding:12px 16px}.section{padding:16px}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light);margin-bottom:10px}.departure-list{display:flex;flex-direction:column;gap:2px}.departure-row{display:flex;align-items:center;padding:10px 16px;background:var(--color-white);gap:12px;cursor:pointer;transition:background .1s;text-decoration:none;color:inherit}.departure-row:hover{background:var(--color-sand);text-decoration:none}.departure-row:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.departure-row:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.departure-row:only-child{border-radius:var(--radius-md)}.departure-time{font-size:1.1rem;font-weight:700;font-variant-numeric:tabular-nums;min-width:80px;color:var(--color-ocean)}.departure-info{flex:1;min-width:0}.departure-route{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.departure-operator{font-size:.72rem;color:var(--color-text-light)}.departure-eta{font-size:.78rem;font-weight:600;color:var(--color-success);white-space:nowrap}.departure-eta.soon{color:var(--color-warning)}.departure-eta.imminent{color:var(--color-danger);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.operator-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;color:var(--color-white)}.tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.68rem;font-weight:500;background:var(--color-foam);color:var(--color-ocean)}.tag.vehicle{background:#e8f5e9;color:#2e7d32}.tag.walk-on{background:#e3f2fd;color:#1565c0}.tag.seasonal{background:#fff3e0;color:#e65100}.tag.first-come{background:#fce4ec;color:#c62828}.search-container{padding:12px 16px;background:var(--color-ocean)}.search-input{width:100%;padding:10px 16px 10px 40px;border:none;border-radius:var(--radius-xl);font-size:.9rem;background:#ffffff26;color:var(--color-white);transition:background .2s}.search-input:focus-visible{outline:2px solid #fff;outline-offset:2px}.search-input::placeholder{color:#fff9}.search-input:focus{background:#ffffff40}.search-wrapper{position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#fff9}.route-header{background:linear-gradient(135deg,var(--color-ocean-dark),var(--color-ocean));color:#fff;padding:20px 16px}.route-header h2{font-size:1.2rem;margin-bottom:4px}.route-header .route-meta{font-size:.8rem;opacity:.85;display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.route-meta span{display:flex;align-items:center;gap:4px}.schedule-direction{padding:12px 16px;background:var(--color-sand);font-weight:600;font-size:.85rem;color:var(--color-ocean);border-bottom:1px solid var(--color-border)}.schedule-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px;padding:12px 16px}.schedule-time{padding:6px 4px;text-align:center;font-size:.82rem;font-weight:500;font-variant-numeric:tabular-nums;background:var(--color-sand);border-radius:var(--radius-sm);color:var(--color-text)}.schedule-time.next{background:var(--color-ocean);color:#fff;font-weight:700}.schedule-time.past{opacity:.4}.operator-list{display:flex;flex-direction:column;gap:8px;padding:16px}.operator-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;text-decoration:none;color:inherit;transition:box-shadow .15s}.operator-card:hover{box-shadow:var(--shadow-md);text-decoration:none}.operator-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0}.operator-details{flex:1;min-width:0}.operator-name{font-weight:600;font-size:.9rem}.operator-type{font-size:.72rem;color:var(--color-text-light);text-transform:capitalize}.operator-arrow{color:var(--color-text-muted);font-size:1.2rem}.map-container{height:calc(100dvh - 120px - var(--nav-height) - var(--safe-bottom));min-height:300px}.map-container .leaflet-container{height:100%;width:100%}.info-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--color-border)}.info-row:last-child{border-bottom:none}.info-label{font-size:.78rem;color:var(--color-text-light);min-width:90px;font-weight:500}.info-value{font-size:.85rem;flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none}.btn-primary{background:var(--color-ocean);color:#fff}.btn-primary:hover{background:var(--color-ocean-light);text-decoration:none}.btn-outline{background:transparent;color:var(--color-ocean);border:1.5px solid var(--color-ocean)}.btn-block{width:100%}.filter-pills{display:flex;gap:6px;padding:12px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-pills::-webkit-scrollbar{display:none}.filter-pill{padding:6px 14px;border-radius:20px;font-size:.78rem;font-weight:500;border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-text-light);white-space:nowrap;cursor:pointer;transition:all .15s}.filter-pill.active{background:var(--color-ocean);color:#fff;border-color:var(--color-ocean)}.empty-state{text-align:center;padding:40px 20px;color:var(--color-text-light)}.empty-state svg{width:48px;height:48px;margin-bottom:12px;opacity:.4}.empty-state p{font-size:.85rem}.back-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 0;background:none;border:none;color:var(--color-foam);font-size:.82rem;cursor:pointer;margin-bottom:4px}@media (min-width: 768px){.app-main{max-width:640px;margin:0 auto;width:100%}.bottom-nav{max-width:640px;left:50%;transform:translate(-50%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.location-prompt{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--color-foam);font-size:.8rem;color:var(--color-ocean);cursor:pointer}.trip-planner-header{background:linear-gradient(135deg,var(--color-ocean-dark),var(--color-ocean));padding:16px}.trip-inputs{display:flex;flex-direction:column;gap:8px;position:relative}.trip-input-group{display:flex;flex-direction:column;gap:4px}.trip-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-foam)}.trip-select{width:100%;padding:10px 12px;border:none;border-radius:var(--radius-md);font-size:.85rem;background:#ffffff26;color:var(--color-white);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.trip-select:focus-visible{outline:2px solid #fff;outline-offset:2px}.trip-select option{color:var(--color-text);background:var(--color-white)}.swap-btn{align-self:center;width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:#ffffff1a;color:var(--color-white);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;margin:-4px 0;z-index:1}.swap-btn:hover{background:#ffffff40}.trip-results{display:flex;flex-direction:column;gap:12px}.trip-card{background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.trip-leg{display:flex;align-items:center;gap:12px;padding:12px 16px;text-decoration:none;color:inherit;transition:background .1s}.trip-leg:hover{background:var(--color-sand);text-decoration:none}.trip-leg-left{flex:1;min-width:0}.trip-leg-route{font-size:.9rem;font-weight:600;margin-top:6px}.trip-leg-meta{font-size:.72rem;color:var(--color-text-light);margin-top:2px}.trip-leg-right{text-align:right;flex-shrink:0}.transfer-badge{display:flex;align-items:center;gap:6px;padding:6px 16px;background:var(--color-foam);font-size:.75rem;font-weight:600;color:var(--color-ocean);border-top:1px dashed var(--color-border)}.trip-fares{display:flex;gap:8px;padding:8px 16px;border-top:1px solid var(--color-border);flex-wrap:wrap}.fare-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--color-sand);border-radius:4px;font-size:.75rem;font-weight:600;color:var(--color-ocean)}.fare-chip-light{color:var(--color-text-light);font-weight:500}.trip-fare-note{padding:4px 16px 10px;font-size:.7rem;color:var(--color-text-muted);line-height:1.4}.fare-card{flex:1;min-width:90px;padding:10px 12px;background:var(--color-sand);border-radius:var(--radius-sm);text-align:center}.fare-card-label{font-size:.68rem;font-weight:500;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.03em;margin-bottom:4px}.fare-card-price{font-size:1.2rem;font-weight:700;color:var(--color-ocean)}.fare-card-sub{font-size:.68rem;color:var(--color-text-muted);margin-top:2px}.alerts-section{display:flex;flex-direction:column}.alert-banner{padding:10px 16px;border-left:4px solid;cursor:pointer;transition:opacity .15s}.alert-banner:not(:last-child){border-bottom:1px solid rgba(0,0,0,.06)}button.alert-banner-header{display:flex;align-items:flex-start;gap:10px;width:100%;background:none;border:none;padding:0;font:inherit;color:inherit;text-align:left;cursor:pointer}.alert-icon{flex-shrink:0;margin-top:1px}.alert-content{flex:1;min-width:0}.alert-title{font-size:.8rem;font-weight:600;color:var(--color-text);line-height:1.3}.alert-summary{font-size:.75rem;color:var(--color-text-light);margin-top:2px;line-height:1.4}.alert-detail{font-size:.75rem;color:var(--color-text);margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.08);line-height:1.5}.alert-expand{flex-shrink:0;font-size:1.1rem;font-weight:300;color:var(--color-text-muted);width:20px;text-align:center}.alerts-toggle{padding:8px 16px;background:none;border:none;font-size:.75rem;font-weight:500;color:var(--color-ocean-light);cursor:pointer;text-align:left}.favorites-list{display:flex;flex-direction:column;gap:4px;padding:0 16px 8px}.favorite-card{display:flex;align-items:center;background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;border-left:3px solid var(--color-warning)}.favorite-card-main{flex:1;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;text-decoration:none;color:inherit;gap:10px;min-width:0}.favorite-card-main:hover{text-decoration:none;background:var(--color-sand)}.favorite-card-left{display:flex;align-items:center;gap:10px;min-width:0}.operator-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.favorite-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.favorite-operator{font-size:.68rem;color:var(--color-text-light)}.favorite-card-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:1px}.favorite-alert-dot{width:8px;height:8px;border-radius:50%;background:var(--color-danger);display:inline-block;margin-bottom:2px;animation:pulse 1.5s ease-in-out infinite}.favorite-star{padding:10px 12px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);transition:color .15s;-webkit-tap-highlight-color:transparent}.favorite-star.active,.favorite-star:hover{color:var(--color-warning)}.favorite-btn-header{background:none;border:none;color:#ffffff80;cursor:pointer;padding:4px;transition:color .15s;-webkit-tap-highlight-color:transparent}.favorite-btn-header.active,.favorite-btn-header:hover{color:#ffd54f}.theme-toggle{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-tap-highlight-color:transparent}.theme-toggle:hover{color:#fff;background:#ffffff1a}.live-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;box-shadow:0 0 6px #4caf5099;animation:live-pulse 2s ease-in-out infinite}.live-dot-sm{width:6px;height:6px;border-radius:50%;background:#4caf50;box-shadow:0 0 4px #4caf5099;animation:live-pulse 2s ease-in-out infinite;flex-shrink:0}@keyframes live-pulse{0%,to{opacity:1;box-shadow:0 0 6px #4caf5099}50%{opacity:.7;box-shadow:0 0 12px #4caf50cc}}.map-toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--color-white);border-bottom:1px solid var(--color-border)}.map-toggle-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:600;border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-text-light);cursor:pointer;transition:all .15s}.map-toggle-btn.active{background:#e8f5e9;border-color:#4caf50;color:#2e7d32}[data-theme=dark] .map-toggle-btn.active{background:#1b3326;border-color:#4caf50;color:#66bb6a}.terminal-waits-bar{display:flex;gap:6px;padding:8px 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--color-white);border-bottom:1px solid var(--color-border)}.terminal-waits-bar::-webkit-scrollbar{display:none}.wait-chip{display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 12px;background:var(--color-sand);border-radius:var(--radius-sm);min-width:70px;flex-shrink:0}.wait-chip-name{font-size:.65rem;font-weight:500;color:var(--color-text-light);white-space:nowrap}.wait-chip-time{font-size:.9rem;font-weight:700;color:var(--color-ocean);font-variant-numeric:tabular-nums}.wait-chip-cars{font-size:.6rem;color:var(--color-text-muted)}.vessel-marker{background:none!important;border:none!important}.capacity-bar{display:flex;align-items:center;gap:6px;margin-top:4px}.capacity-bar-track{flex:1;height:5px;background:var(--color-border);border-radius:3px;overflow:hidden}.capacity-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.capacity-bar-label{font-size:.68rem;font-weight:600;min-width:32px;text-align:right}.live-vessels-panel{background:var(--color-white);border-bottom:1px solid var(--color-border)}.live-vessels-header{display:flex;align-items:center;gap:6px;padding:10px 16px 6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#4caf50}.live-vessel-row{display:flex;align-items:center;gap:12px;padding:8px 16px;border-top:1px solid var(--color-border)}.live-vessel-info{flex:1;min-width:0}.live-vessel-name{font-size:.82rem;font-weight:600}.live-vessel-meta{font-size:.7rem;color:var(--color-text-light);margin-top:1px}.live-vessel-load{width:100px;flex-shrink:0}.terminal-wait-badge{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--color-white);border-bottom:1px solid var(--color-border)}.terminal-wait-badge .wait-label{font-size:.75rem;color:var(--color-text-light)}.terminal-wait-badge .wait-value{font-size:1.1rem;font-weight:700;color:var(--color-ocean)}.terminal-wait-badge .wait-detail{font-size:.7rem;color:var(--color-text-muted)}.install-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:var(--color-ocean);color:#fff}.install-banner-content{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.install-banner-icon{flex-shrink:0;opacity:.85}.install-banner-text{min-width:0}.install-banner-title{font-size:.82rem;font-weight:600;line-height:1.3}.install-banner-subtitle{font-size:.7rem;opacity:.75;margin-top:1px}.install-banner-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.install-dismiss{background:none;border:none;color:#fff9;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.install-dismiss:hover{color:#fff}.toast{position:fixed;bottom:calc(var(--nav-height) + var(--safe-bottom) + 16px);left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-white);padding:10px 20px;border-radius:var(--radius-xl);font-size:.82rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:200;animation:toast-in .3s ease-out;white-space:nowrap}[data-theme=dark] .toast{background:#d8e4f0;color:#0f1923}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.header-action-btn{background:none;border:none;color:#fff9;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .15s;-webkit-tap-highlight-color:transparent}.header-action-btn:hover{color:#fff}.schedule-grid-notify{display:flex;flex-direction:column;gap:4px;padding:12px 16px}.schedule-time-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--color-sand);border-radius:var(--radius-sm)}[data-theme=dark] .schedule-time-row{background:#1a2a3a}.schedule-time-row.next{background:var(--color-ocean)}.schedule-time-row.next .schedule-time-value{color:#fff;font-weight:700}.schedule-time-row.next .schedule-eta{color:#fffc}.schedule-time-row.past{opacity:.4}.schedule-time-value{font-size:.82rem;font-weight:500;font-variant-numeric:tabular-nums;color:var(--color-text);min-width:70px}.schedule-eta{flex:1;font-size:.72rem;color:var(--color-text-light)}.notify-btn{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .15s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.notify-btn:hover{color:var(--color-ocean)}.notify-btn.active{color:var(--color-warning)}.schedule-time-row.next .notify-btn{color:#ffffff80}.schedule-time-row.next .notify-btn:hover,.schedule-time-row.next .notify-btn.active{color:#ffd54f}.offline-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 16px;background:#455a64;color:#fff;font-size:.78rem}[data-theme=dark] .offline-banner{background:#263238}.offline-banner-left{display:flex;align-items:center;gap:8px}.offline-banner-text{display:flex;flex-direction:column;gap:1px}.offline-banner-title{font-weight:600;font-size:.78rem}.offline-banner-updated{font-size:.68rem;opacity:.75}.offline-banner-warning{font-size:.68rem;padding:2px 8px;background:#ffffff26;border-radius:4px;white-space:nowrap}.offline-dot{width:8px;height:8px;border-radius:50%;background:#78909c;box-shadow:0 0 4px #78909c80}.cache-badge{display:flex;align-items:center;justify-content:center;color:#ffffff80;padding:2px}.simulated-badge,.live-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.simulated-badge{background:#fff3e0;color:#e65100;border:1px solid #ffcc80}.live-badge{background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}[data-theme=dark] .simulated-badge{background:#3e2a10;color:#ffb74d;border-color:#5a3e1a}[data-theme=dark] .live-badge{background:#1b3326;color:#66bb6a;border-color:#2e5a3e}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--color-white);display:flex;flex-direction:column;align-items:center;justify-content:center}.onboarding-skip{position:absolute;top:16px;right:16px;background:none;border:none;font-size:.85rem;font-weight:500;color:var(--color-text-light);cursor:pointer;padding:8px 12px;z-index:1}.onboarding-slides{display:flex;width:100%;transition:transform .35s ease-out}.onboarding-slide{min-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px;text-align:center}.onboarding-icon{color:var(--color-ocean);margin-bottom:24px}.onboarding-title{font-size:1.3rem;font-weight:700;color:var(--color-text);margin-bottom:12px}.onboarding-desc{font-size:.9rem;color:var(--color-text-light);line-height:1.6;max-width:320px}.onboarding-footer{position:absolute;bottom:48px;display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;padding:0 32px}.onboarding-dots{display:flex;gap:8px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:background .2s}.onboarding-dot.active{background:var(--color-ocean)}.onboarding-btn{width:100%;max-width:280px;padding:14px 24px;background:var(--color-ocean);color:#fff;border:none;border-radius:var(--radius-xl);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.onboarding-btn:hover{background:var(--color-ocean-light)}.saved-trips-list{display:flex;flex-direction:column;gap:4px;padding:0 16px 8px}.saved-trip-card{display:flex;align-items:center;background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;border-left:3px solid var(--color-ocean)}.saved-trip-main{flex:1;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;text-decoration:none;color:inherit;gap:10px;min-width:0}.saved-trip-main:hover{text-decoration:none;background:var(--color-sand)}.saved-trip-left{min-width:0}.saved-trip-name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-trip-terminals{font-size:.68rem;color:var(--color-text-light)}.saved-trip-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:1px}.saved-trip-remove{padding:10px 12px;background:none;border:none;cursor:pointer;color:var(--color-text-muted);transition:color .15s;-webkit-tap-highlight-color:transparent}.saved-trip-remove:hover{color:var(--color-danger)}.save-trip-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:none;border:1.5px solid var(--color-ocean);border-radius:20px;font-size:.7rem;font-weight:600;color:var(--color-ocean);cursor:pointer;text-transform:none;letter-spacing:0;transition:all .15s}.save-trip-btn:hover{background:var(--color-ocean);color:#fff}.schedule-date-picker{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--color-white);border-bottom:1px solid var(--color-border)}.date-pill{padding:6px 14px;border-radius:20px;font-size:.78rem;font-weight:500;border:1.5px solid var(--color-border);background:var(--color-white);color:var(--color-text-light);white-space:nowrap;cursor:pointer;transition:all .15s}.date-pill.active{background:var(--color-ocean);color:#fff;border-color:var(--color-ocean)}.date-input{padding:6px 10px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.78rem;font-family:inherit;background:var(--color-white);color:var(--color-text);cursor:pointer}[data-theme=dark] .date-input{background:#1a2a3a;border-color:#2a3a4a;color:var(--color-text);color-scheme:dark}[data-theme=dark] .date-pill{background:#1a2a3a;border-color:#2a3a4a}.weather-card{background:var(--color-white);border-bottom:1px solid var(--color-border)}.weather-card-header{display:flex;align-items:center;gap:10px;padding:12px 16px 6px}.weather-icon{color:var(--color-ocean);flex-shrink:0}.weather-temp{font-size:1.3rem;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.weather-condition{font-size:.82rem;color:var(--color-text-light)}.weather-details{display:flex;gap:16px;padding:6px 16px 12px}.weather-detail{display:flex;flex-direction:column;gap:1px}.weather-detail-label{font-size:.68rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.weather-detail-value{font-size:.82rem;font-weight:600;color:var(--color-text)}.weather-warning{color:var(--color-warning)}.weather-advisory{padding:8px 16px;font-size:.75rem;font-weight:500;background:#fce4ec;color:#c62828;border-top:1px solid var(--color-border)}.weather-advisory-moderate{background:#fff3e0;color:#e65100}[data-theme=dark] .weather-advisory{background:#3e1a1a;color:#ef9a9a}[data-theme=dark] .weather-advisory-moderate{background:#3e2a10;color:#ffb74d}.route-weather-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-sand);border-bottom:1px solid var(--color-border);font-size:.78rem;color:var(--color-text-light)}.weather-icon-sm{color:var(--color-ocean);display:flex;align-items:center;flex-shrink:0}.tide-card{background:var(--color-white);border-bottom:1px solid var(--color-border)}.tide-card-header{display:flex;align-items:center;gap:8px;padding:10px 16px 6px;color:var(--color-ocean)}.tide-card-title{font-size:.82rem;font-weight:600;color:var(--color-text)}.tide-list{display:flex;gap:2px;padding:4px 16px 12px;flex-wrap:wrap}.tide-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;font-size:.78rem;background:var(--color-sand);position:relative}.tide-item.tide-past{opacity:.45}.tide-item.tide-next{background:#e3f2fd;font-weight:600}[data-theme=dark] .tide-item.tide-next{background:#1a3a5c}.tide-type{font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.03em;min-width:28px}.tide-high{color:#1565c0}.tide-low{color:#e65100}[data-theme=dark] .tide-high{color:#64b5f6}[data-theme=dark] .tide-low{color:#ffb74d}.tide-time{color:var(--color-text);font-variant-numeric:tabular-nums}.tide-height{color:var(--color-text-light);font-size:.72rem}.tide-next-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;color:var(--color-ocean);letter-spacing:.04em}.route-tide-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--color-sand);border-bottom:1px solid var(--color-border);font-size:.78rem;color:var(--color-text-light)}.tide-icon-sm{color:var(--color-ocean);display:flex;align-items:center;flex-shrink:0}.lang-switcher{position:relative}.lang-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.25);color:#fffc;padding:3px 8px;border-radius:4px;font-size:.65rem;font-weight:700;cursor:pointer;letter-spacing:.03em;transition:all .15s;-webkit-tap-highlight-color:transparent}.lang-btn:hover{background:#fff3;color:#fff}.lang-dropdown{position:absolute;top:100%;right:0;margin-top:6px;background:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;z-index:1100;min-width:120px}.lang-option{display:block;width:100%;padding:10px 16px;background:none;border:none;font-size:.85rem;color:var(--color-text);cursor:pointer;text-align:left;transition:background .1s}.lang-option:hover{background:var(--color-sand)}.lang-option.active{color:var(--color-ocean);font-weight:600}.lang-option:not(:last-child){border-bottom:1px solid var(--color-border)}
