/* ============================================================
   LuxNautic — taxi boat page styles
   ============================================================ */

.ln-taxi-section { padding: 80px 0; }
.ln-taxi-section--alt { background: var(--ln-off-white); }
.ln-taxi-section--dark { background: var(--ln-secondary); color: var(--ln-white); }
.ln-taxi-section--dark h2 { color: var(--ln-white); }
.ln-taxi-section--dark .ln-eyebrow { color: var(--ln-accent); }

.ln-taxi-section h2 { color: var(--ln-secondary); margin-bottom: var(--ln-space-5); max-width: 740px; }
.ln-taxi-section p.lead { font-size: 17px; line-height: 1.7; max-width: 720px; margin-bottom: var(--ln-space-8); }

@media (max-width: 768px) {
	.ln-taxi-section { padding: 50px 0; }
}

/* "How it works" 3 steps */
.ln-taxi-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; margin-top: var(--ln-space-8); }
.ln-taxi-step__num { font-family: var(--ln-font-serif); font-size: 56px; color: var(--ln-accent); line-height: 1; margin-bottom: 12px; font-weight: 400; }
.ln-taxi-step h3 { color: var(--ln-secondary); font-size: 19px; margin-bottom: 8px; }
.ln-taxi-step p { font-size: 14px; line-height: 1.7; color: var(--ln-text); margin: 0; }

@media (max-width: 768px) {
	.ln-taxi-steps { grid-template-columns: 1fr; gap: 30px; }
}

/* Two-boat fleet display */
.ln-fleet { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.ln-fleet__item { background: var(--ln-white); box-shadow: var(--ln-shadow-card); }
.ln-fleet__media { aspect-ratio: 16 / 10; overflow: hidden; }
.ln-fleet__media img { width: 100%; height: 100%; object-fit: cover; }
.ln-fleet__body { padding: var(--ln-space-6); }
.ln-fleet__body h3 { color: var(--ln-secondary); font-size: 22px; margin-bottom: 4px; }
.ln-fleet__body small { display: block; color: var(--ln-accent); font-size: 12px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }
.ln-fleet__body p { font-size: 14px; line-height: 1.7; color: var(--ln-text); margin: 0 0 12px; }
.ln-fleet__specs { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; padding-top: 12px; border-top: 1px solid var(--ln-divider); font-size: 13px; }
.ln-fleet__specs span { display: block; }
.ln-fleet__specs strong { display: block; font-weight: var(--ln-fw-semibold); color: var(--ln-secondary); font-size: 16px; margin-top: 2px; }

@media (max-width: 768px) {
	.ln-fleet { grid-template-columns: 1fr; gap: 24px; }
}

/* Map + routes layout */
.ln-routes-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 40px; align-items: start; }
.ln-routes-map { background: var(--ln-white); padding: var(--ln-space-4); box-shadow: var(--ln-shadow-card); position: sticky; top: 100px; }
.ln-routes-map svg { width: 100%; height: auto; display: block; }
.ln-routes-list h3 { color: var(--ln-secondary); font-size: 17px; margin: 0 0 var(--ln-space-3); display: flex; align-items: center; gap: 10px; }
.ln-routes-list h3 .ln-tier-dot { width: 12px; height: 12px; border-radius: 50%; flex: 0 0 auto; }
.ln-routes-list h3 .ln-tier-dot--solid { background: var(--ln-accent); }
.ln-routes-list h3 .ln-tier-dot--ring { background: transparent; border: 2px solid var(--ln-accent); }
.ln-routes-list h3 .ln-tier-dot--special { background: var(--ln-secondary); border: 2px solid var(--ln-accent); }
.ln-routes-list ul { list-style: none; padding: 0; margin: 0 0 var(--ln-space-6); display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; font-size: 14px; }
.ln-routes-list li { display: flex; align-items: center; gap: 8px; padding: 10px 12px; background: var(--ln-white); border-left: 2px solid var(--ln-accent-soft); }
.ln-routes-list li::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--ln-accent); flex: 0 0 auto; }
.ln-routes-list .ln-routes-meta { font-size: 12px; color: var(--ln-text); margin: 0 0 14px; padding: 8px 12px; background: var(--ln-accent-soft); border-left: 2px solid var(--ln-accent); }

@media (max-width: 1024px) {
	.ln-routes-grid { grid-template-columns: 1fr; }
	.ln-routes-map { position: static; }
}

/* SVG map specifics */
.ln-map { font-family: var(--ln-font-sans); }
.ln-map .sea { fill: #e8f3fb; }
.ln-map .land { fill: #f0f0eb; stroke: #d6dee5; stroke-width: 1.5; }
.ln-map .grid-line { stroke: rgba(15,33,43,0.04); stroke-width: 0.5; }
.ln-map .route { stroke-width: 1.6; fill: none; opacity: 0.7; stroke-dasharray: 4 4; }
.ln-map .route--tier4 { stroke: var(--ln-accent); }
.ln-map .route--tier2 { stroke: var(--ln-secondary); opacity: 0.5; }
.ln-map .route--brijuni { stroke: var(--ln-accent); stroke-width: 2; opacity: 0.9; stroke-dasharray: 6 3; }
.ln-map .pin-circle { fill: var(--ln-white); stroke: var(--ln-accent); stroke-width: 2; }
.ln-map .pin-circle--tier4 { fill: var(--ln-accent); stroke: var(--ln-secondary); stroke-width: 1.5; }
.ln-map .pin-circle--special { fill: var(--ln-secondary); stroke: var(--ln-accent); stroke-width: 2; }
.ln-map .origin-pulse { fill: var(--ln-accent); opacity: 0.3; transform-origin: center; animation: ln-pulse 2.5s ease-out infinite; }
.ln-map .origin-core { fill: var(--ln-secondary); stroke: var(--ln-white); stroke-width: 3; }
.ln-map .origin-core--cap { fill: var(--ln-accent); }
.ln-map .label { font-size: 13px; fill: var(--ln-secondary); font-weight: 500; pointer-events: none; }
.ln-map .label--small { font-size: 11px; fill: var(--ln-text); }
.ln-map .label--origin { font-size: 16px; fill: var(--ln-secondary); font-weight: 600; }
.ln-map .compass { font-size: 11px; fill: var(--ln-text); letter-spacing: 2px; }
.ln-map .legend { font-size: 11px; fill: var(--ln-text); }

@keyframes ln-pulse {
	0%   { transform: scale(0.6); opacity: 0.6; }
	100% { transform: scale(2.4); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
	.ln-map .origin-pulse { animation: none; opacity: 0.2; }
}

/* FAQ block */
.ln-faq { display: grid; gap: 12px; max-width: 780px; }
.ln-faq__item { background: var(--ln-white); border-left: 2px solid var(--ln-accent); }
.ln-faq__q { padding: 18px 22px; font-weight: var(--ln-fw-semibold); color: var(--ln-secondary); font-size: 15px; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.ln-faq__q::-webkit-details-marker { display: none; }
.ln-faq__q::after { content: "+"; font-size: 22px; font-weight: 300; color: var(--ln-accent); transition: transform var(--ln-trans-fast); }
.ln-faq__item[open] .ln-faq__q::after { transform: rotate(45deg); }
.ln-faq__a { padding: 0 22px 22px; color: var(--ln-text); font-size: 14px; line-height: 1.7; }

/* Contact CTA cards */
.ln-taxi-contact { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; max-width: 920px; margin: 0 auto; }
.ln-taxi-contact a { display: block; background: rgba(255,255,255,0.05); border: 1px solid rgba(126,193,243,0.3); padding: 24px; text-align: center; color: var(--ln-white); transition: all var(--ln-trans-base); }
.ln-taxi-contact a:hover { background: var(--ln-accent); color: var(--ln-secondary); border-color: var(--ln-accent); }
.ln-taxi-contact a strong { display: block; font-size: 18px; font-weight: var(--ln-fw-semibold); margin-bottom: 4px; }
.ln-taxi-contact a small { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; opacity: 0.85; }
