/*
 * Transport connections (web-app) — map markers, detail sheet, list overlay.
 * Loaded on index.html; paired with js/transport-manager.js.
 */

/* -- map markers ------------------------------------------------------ */
.transport-station-marker .ts-pin { position:relative; width:26px; height:26px; border-radius:50%; background:#fff; border:2px solid #0ea5e9; display:flex; align-items:center; justify-content:center; box-shadow:0 1px 4px rgba(0,0,0,.3); }
.transport-station-marker .ts-pin span { font-size:13px; line-height:1; }
.transport-station-marker .ts-count { position:absolute; top:-6px; right:-6px; min-width:15px; height:15px; padding:0 3px; border-radius:8px; background:#0f172a; color:#fff; font-size:10px; font-weight:700; font-style:normal; line-height:15px; text-align:center; box-shadow:0 1px 2px rgba(0,0,0,.4); }
.transport-station-marker .ts-warn { position:absolute; bottom:-5px; right:-5px; font-size:11px; font-style:normal; line-height:1; filter:drop-shadow(0 1px 1px rgba(0,0,0,.4)); }
.transport-cluster-icon { background:transparent; }
.transport-cluster { width:100%; height:100%; border-radius:50%; background:#0ea5e9; border:2px solid #fff; color:#fff; font-weight:700; font-size:13px; display:flex; align-items:center; justify-content:center; box-shadow:0 1px 5px rgba(0,0,0,.4); }

/* -- shared-quay board ------------------------------------------------ */
.transport-quay-list { display:flex; flex-direction:column; gap:8px; margin-top:6px; }
.transport-quay-row { display:flex; align-items:center; gap:10px; width:100%; text-align:left; background:#f8fafc; border:1px solid #e2e8f0; border-radius:10px; padding:10px 12px; cursor:pointer; }
.transport-quay-row:hover { background:#f1f5f9; }
.transport-quay-icon { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:15px; flex-shrink:0; }
.transport-quay-dest { flex:1; font-size:15px; font-weight:600; color:#0f172a; }
.transport-quay-time { font-size:16px; font-weight:700; color:#0369a1; }
.leaflet-control.transport-toggle a { font-size:18px; line-height:30px; text-align:center; width:30px; height:30px; display:block; background:#fff; }

/* -- live vessel marker ----------------------------------------------- */
.xn-vessel-marker .xn-vessel { position:relative; width:34px; height:34px; }
.xn-vessel-marker .xn-vessel-dir { position:absolute; inset:0; transition: transform .5s linear; }
.xn-vessel-marker .xn-vessel-dir::before { content:''; position:absolute; top:-1px; left:50%; transform:translateX(-50%); width:0; height:0; border-left:6px solid transparent; border-right:6px solid transparent; border-bottom:9px solid #0ea5e9; filter: drop-shadow(0 1px 1px rgba(0,0,0,.4)); }
.xn-vessel-marker .xn-vessel-badge { position:absolute; inset:5px; border-radius:50%; background:#fff; display:flex; align-items:center; justify-content:center; font-size:15px; line-height:1; box-shadow:0 1px 4px rgba(0,0,0,.45); animation: xnVesselGlow 1.4s ease-in-out infinite; }
.xn-vessel-marker .xn-vessel-pulse { position:absolute; left:50%; top:50%; width:24px; height:24px; margin:-12px 0 0 -12px; border-radius:50%; background:rgba(14,165,233,.5); z-index:-1; animation: xnVesselPulse 1.4s ease-out infinite; }
@keyframes xnVesselPulse { 0%{ transform:scale(.7); opacity:.7 } 100%{ transform:scale(2.6); opacity:0 } }
@keyframes xnVesselGlow { 0%,100%{ box-shadow:0 1px 4px rgba(0,0,0,.45), 0 0 0 0 rgba(14,165,233,.7) } 50%{ box-shadow:0 1px 4px rgba(0,0,0,.45), 0 0 7px 3px rgba(14,165,233,.9) } }

/* -- detail sheet: header / chips / direction ------------------------- */
.transport-route-line { font-size:15px; font-weight:600; color:#0f172a; margin:4px 0 8px; }
.transport-arrow { color:#94a3b8; margin:0 4px; }
.transport-chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.transport-chip { font-size:12px; background:#f1f5f9; color:#0f172a; padding:3px 10px; border-radius:12px; font-weight:600; }
.transport-chip .tc-key { font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:#94a3b8; margin-right:2px; }
.transport-direction { margin-bottom:10px; }
.transport-direction-label { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.04em; color:#64748b; margin-bottom:5px; }
.transport-dir-btns { display:flex; flex-wrap:wrap; gap:6px; }
.transport-dir-select { width:100%; font-size:14px; font-weight:600; color:#0f172a; background:#fff; border:1px solid #bae6fd; border-radius:8px; padding:8px 12px; cursor:pointer; }
.transport-dir-btn { font-size:13px; font-weight:600; color:#0369a1; background:#fff; border:1px solid #bae6fd; padding:6px 12px; border-radius:8px; cursor:pointer; }
.transport-dir-btn.active { background:#0ea5e9; color:#fff; border-color:#0ea5e9; }

/* -- detail sheet: departure board ------------------------------------ */
.transport-departure-label { font-size:12px; color:#64748b; text-transform:uppercase; letter-spacing:.04em; }
.transport-departure-value { font-size:18px; font-weight:700; color:#0f172a; }
.transport-timetable-link { color:#0ea5e9; font-weight:600; text-decoration:none; }
.transport-board { background:#f8fafc; border:1px solid #e2e8f0; border-radius:10px; padding:10px 14px; margin-bottom:12px; }
.transport-board-loading .transport-departure-value { color:#cbd5e1; }
.transport-board .tb-from { font-size:11px; text-transform:uppercase; letter-spacing:.04em; color:#64748b; margin-bottom:8px; }
.transport-board .tb-daydate { font-size:11px; font-weight:700; color:#b45309; background:#fef3c7; border-radius:6px; padding:1px 6px; margin-left:6px; white-space:nowrap; }
.transport-board .tb-dir { padding:6px 0; border-top:1px solid #eef2f7; }
.transport-board .tb-dir:first-child { border-top:0; }
.transport-board .tb-dest { font-size:14px; font-weight:700; color:#0f172a; margin-bottom:4px; }
.transport-board .tb-times { display:flex; flex-wrap:wrap; gap:6px; }
.transport-board .tb-time { font-size:14px; font-weight:600; color:#475569; background:#fff; border:1px solid #e2e8f0; border-radius:6px; padding:2px 8px; }
.transport-board .tb-time.tb-next { color:#fff; background:#0ea5e9; border-color:#0ea5e9; }
.transport-board .tb-toggle { margin-top:10px; width:100%; font-size:13px; font-weight:600; color:#0369a1; background:#fff; border:1px solid #bae6fd; border-radius:8px; padding:7px 12px; cursor:pointer; }
.transport-board .tb-toggle:hover { background:#f0f9ff; }

/* -- detail sheet: premium teaser / live ------------------------------ */
.transport-premium-lock { background:linear-gradient(135deg,#eff6ff,#f0f9ff); border:1px solid #bae6fd; border-radius:12px; padding:14px 16px; margin-bottom:14px; }
.transport-lock-head { display:flex; align-items:center; gap:8px; color:#0369a1; margin-bottom:6px; }
.transport-lock-icon { font-size:15px; }
.transport-premium-lock p { font-size:13px; color:#475569; margin:0 0 12px; line-height:1.5; }
.transport-getapp-btn { display:inline-block; background:#0ea5e9; color:#fff; font-weight:600; font-size:14px; padding:9px 18px; border-radius:8px; text-decoration:none; }
.transport-code-redeem { margin-top:12px; padding-top:12px; border-top:1px solid #bae6fd; }
.transport-code-label { display:block; font-size:12px; font-weight:600; color:#0369a1; margin-bottom:6px; }
.transport-code-row { display:flex; gap:8px; }
.transport-code-input { flex:1; min-width:0; font-size:14px; border:1px solid #bae6fd; border-radius:8px; padding:8px 10px; outline:none; }
.transport-code-input:focus { border-color:#0ea5e9; box-shadow:0 0 0 3px rgba(14,165,233,.15); }
.transport-code-btn { flex-shrink:0; font-size:14px; font-weight:600; color:#fff; background:#0f172a; border:none; border-radius:8px; padding:8px 16px; cursor:pointer; }
.transport-code-btn:disabled { opacity:.5; cursor:default; }
.transport-code-msg { font-size:12px; margin:6px 0 0; min-height:1em; color:#15803d; }
.transport-code-msg.err { color:#b45309; }
.transport-live { margin-bottom:14px; }
.transport-live-status { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:600; color:#15803d; padding:8px 0; }
.transport-live-status.muted { color:#94a3b8; }
.transport-live-note { font-size:11px; color:#94a3b8; line-height:1.4; margin-top:6px; }
.transport-alert-dates { font-size:12px; color:#92400e; margin:4px 0 0; font-weight:600; }
.transport-alert-link { display:inline-block; margin-top:4px; font-size:13px; font-weight:600; color:#b45309; text-decoration:none; }
.transport-vessel-row { font-size:13px; color:#475569; padding:3px 6px; margin-left:11px; border-radius:6px; cursor:pointer; }
.transport-vessel-row:hover { background:#f1f5f9; color:#0369a1; }
.transport-live-dot { width:9px; height:9px; border-radius:50%; background:#22c55e; box-shadow:0 0 0 0 rgba(34,197,94,.6); animation: xnPulse 1.6s infinite; }
@keyframes xnPulse { 0%{box-shadow:0 0 0 0 rgba(34,197,94,.6)} 70%{box-shadow:0 0 0 8px rgba(34,197,94,0)} 100%{box-shadow:0 0 0 0 rgba(34,197,94,0)} }

/* -- detail sheet: notes / stops / booking ---------------------------- */
.transport-notes { margin:8px 0 12px; }
.transport-note { font-size:13px; color:#475569; margin-bottom:4px; line-height:1.5; }
.transport-stops { margin:14px 0; }
.transport-stops h3 { font-size:14px; font-weight:700; color:#334155; margin-bottom:6px; }
.transport-stops ul { list-style:none; padding:0; margin:0; }
.transport-stops li { font-size:14px; color:#475569; padding:4px 0 4px 18px; position:relative; }
.transport-stops li:before { content:'•'; position:absolute; left:4px; color:#0ea5e9; }
.transport-stops li.ts-stop-ondemand:before { content:'⚠'; color:#b45309; font-size:11px; top:5px; }
.ts-ondemand-badge { font-size:11px; font-weight:700; color:#b45309; background:#fef3c7; border-radius:10px; padding:1px 7px; margin-left:4px; white-space:nowrap; }
.ts-booking-selected { margin-bottom:12px; }
.ts-booking-head { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; color:#b45309; margin-bottom:4px; }
.ts-booking { margin:6px 0 4px; padding:10px 12px; background:#fffbeb; border:1px solid #fde68a; border-radius:8px; }
.ts-booking-warn { font-size:13px; color:#92400e; line-height:1.5; margin:0; }
.ts-booking-deadline { font-size:12px; color:#475569; margin:6px 0 0; }
.ts-booking-actions { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.ts-book-btn { display:inline-flex; align-items:center; gap:4px; font-size:13px; font-weight:600; color:#fff; background:#0ea5e9; border-radius:8px; padding:6px 12px; text-decoration:none; }
.ts-book-chip { display:inline-flex; align-items:center; gap:4px; font-size:13px; font-weight:600; color:#0369a1; background:#e0f2fe; border-radius:8px; padding:6px 12px; }
.transport-book-btn { display:inline-block; margin-top:8px; background:#0f172a; color:#fff; font-weight:600; font-size:14px; padding:10px 20px; border-radius:8px; text-decoration:none; }
.transport-report-row { margin-top:16px; padding-top:16px; border-top:1px solid #e5e7eb; }
.transport-report-btn { display:inline-flex; align-items:center; gap:6px; font-size:13px; color:#6b7280; background:none; border:none; cursor:pointer; padding:8px 0; }
.transport-report-btn:hover { color:#b45309; }

/* -- route line emphasis (selected vs dimmed) ------------------------- */
.transport-route { transition:stroke-width .15s ease, stroke-opacity .15s ease; }
.transport-route-selected { filter:drop-shadow(0 1px 4px rgba(0,0,0,.45)); }

/* -- searchable list overlay + filter bar ----------------------------- */
.transport-list-overlay { position:fixed; inset:0; background:#fff; z-index:1400; display:flex; flex-direction:column; }
.transport-list-overlay.hidden { display:none; }
.transport-list-head { display:flex; align-items:center; gap:10px; padding:14px 16px; border-bottom:1px solid #e5e7eb; }
.transport-list-close { color:#475569; flex-shrink:0; }
.transport-filter-bar { display:flex; flex-wrap:wrap; align-items:center; gap:8px; padding:10px 16px; border-bottom:1px solid #f1f5f9; }
.transport-filter-types { display:flex; flex-wrap:wrap; gap:8px; }
.transport-filter-sep { width:1px; align-self:stretch; background:#e5e7eb; margin:2px 0; }
.transport-filter-chip { font-size:13px; font-weight:600; color:#475569; background:#f1f5f9; border:1px solid #e2e8f0; border-radius:999px; padding:6px 14px; cursor:pointer; transition:all .12s; white-space:nowrap; }
.transport-filter-chip:hover { background:#e2e8f0; }
.transport-filter-chip.active { color:#fff; background:#0ea5e9; border-color:#0ea5e9; }
.transport-filter-chip.active:hover { background:#0284c7; }
#transport-filter-inservice.active::before { content:'✓ '; }
.transport-type-chip .tfc-icon { font-size:13px; }
.tli-season-badge { font-size:11px; font-weight:700; color:#64748b; background:#f1f5f9; border-radius:10px; padding:1px 7px; margin-left:4px; white-space:nowrap; }
.transport-list-item-off .tli-icon { opacity:.55; }
.transport-list-item-off .tli-name { color:#475569; }
.transport-list-input { flex:1; font-size:16px; border:1px solid #e2e8f0; border-radius:10px; padding:10px 14px; outline:none; }
.transport-list-input:focus { border-color:#0ea5e9; box-shadow:0 0 0 3px rgba(14,165,233,.15); }
.transport-list-results { flex:1; overflow-y:auto; }
.transport-list-empty { text-align:center; color:#94a3b8; padding:40px 16px; font-size:14px; }
.transport-list-item { display:flex; align-items:center; gap:12px; width:100%; text-align:left; padding:12px 16px; border-bottom:1px solid #f1f5f9; cursor:pointer; background:#fff; }
.transport-list-item:hover { background:#f8fafc; }
.tli-icon { width:36px; height:36px; flex-shrink:0; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; }
.tli-info { display:flex; flex-direction:column; min-width:0; }
.tli-name { font-size:15px; font-weight:700; color:#0f172a; }
.tli-sub { font-size:13px; color:#64748b; margin-top:1px; }
.tli-type { color:#94a3b8; margin-left:6px; }
