/* Flying Nomads Blocks — Frontend CSS v2.0 */
:root {
    --fnb-orange: #D97B48;
    --fnb-dark: #2d2d2d;
    --fnb-border: #e8e8e8;
    --fnb-muted: #888;
    --fnb-green: #3B6D11;
    --fnb-green-bg: #EAF3DE;
    --fnb-green-border: #C0DD97;
    --fnb-blue: #185FA5;
    --fnb-blue-bg: #E6F1FB;
    --fnb-blue-border: #B5D4F4;
    --fnb-amber: #854F0B;
    --fnb-amber-bg: #FAEEDA;
    --fnb-amber-border: #FAC775;
    --fnb-red-bg: #FFF2F2;
    --fnb-red: #7A1F1F;
}

/* ── SHARED ───────────────────────────────────────────────── */
.fnb-block { border: 1px solid var(--fnb-border); margin: 28px 0; font-size: 15px; line-height: 1.7; }
.fnb-block-header { display: flex; align-items: center; gap: 10px; padding: 11px 16px; border-bottom: 1px solid var(--fnb-border); }
.fnb-block-icon { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.fnb-block-title { font-size: 13px; font-weight: 600; font-family: 'Outfit', sans-serif; }
.fnb-block-body { padding: 12px 16px; font-size: 14px; line-height: 1.7; }
.fnb-block-body a { color: var(--fnb-orange); text-decoration: none; }
.fnb-block-body strong { font-weight: 600; }

/* ── TIP ── */
.fnb-tip .fnb-block-header { background: var(--fnb-green-bg); border-bottom-color: var(--fnb-green-border); }
.fnb-tip .fnb-block-icon { background: var(--fnb-green-border); color: var(--fnb-green); }
.fnb-tip .fnb-block-title { color: #27500A; }
.fnb-tip .fnb-block-body { background: var(--fnb-green-bg); color: #27500A; }

/* ── WARNING ── */
.fnb-warning .fnb-block-header { background: var(--fnb-amber-bg); border-bottom-color: var(--fnb-amber-border); }
.fnb-warning .fnb-block-icon { background: var(--fnb-amber-border); color: var(--fnb-amber); }
.fnb-warning .fnb-block-title { color: #633806; }
.fnb-warning .fnb-block-body { background: var(--fnb-amber-bg); color: #633806; }

/* ── PHOTO TIP ── */
.fnb-phototip .fnb-block-header { background: var(--fnb-blue-bg); border-bottom-color: var(--fnb-blue-border); }
.fnb-phototip .fnb-block-icon { background: var(--fnb-blue-border); color: var(--fnb-blue); }
.fnb-phototip .fnb-block-title { color: #0C447C; }
.fnb-phototip .fnb-block-body { background: var(--fnb-blue-bg); color: #0C447C; }

/* ── PULL QUOTE ── */
.fnb-pullquote { border-top: 2px solid var(--fnb-orange); border-bottom: 2px solid var(--fnb-orange); padding: 16px 0; margin: 32px 0; text-align: center; }
.fnb-pullquote-text { font-size: 18px; font-style: italic; font-family: 'Prata', Georgia, serif; color: var(--fnb-dark); line-height: 1.6; }
.fnb-pullquote-author { font-size: 12px; color: var(--fnb-muted); margin-top: 10px; text-transform: uppercase; letter-spacing: 1px; font-family: 'Outfit', sans-serif; }

/* ── SLEEP ── */
.fnb-sleep { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--fnb-muted); margin: 4px 0 20px; font-family: 'Outfit', sans-serif; }
.fnb-sleep svg { color: var(--fnb-orange); flex-shrink: 0; }
.fnb-sleep-label { color: var(--fnb-muted); }
.fnb-sleep a { color: var(--fnb-orange); text-decoration: none; font-weight: 500; }
.fnb-sleep a:hover { text-decoration: underline; }
.fnb-sleep-nights { background: #f5f5f5; border: 1px solid var(--fnb-border); font-size: 11px; padding: 1px 7px; margin-left: 4px; color: var(--fnb-muted); }

/* ── AFFILIATE ── */
.fnb-affiliate { border-left: 3px solid var(--fnb-orange); background: #fff8f4; padding: 11px 16px; margin: 20px 0; font-size: 13px; color: #555; line-height: 1.65; }
.fnb-affiliate-label { font-family: 'Outfit', sans-serif; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.6px; color: var(--fnb-orange); margin-bottom: 4px; display: flex; align-items: center; gap: 5px; }
.fnb-affiliate a { color: var(--fnb-orange); font-weight: 500; text-decoration: none; }
.fnb-affiliate a:hover { text-decoration: underline; }

/* ── BUDGET ── */
.fnb-budget { border: 1px solid var(--fnb-border); margin: 28px 0; overflow: hidden; }
.fnb-budget-header { background: var(--fnb-dark); padding: 12px 18px; display: flex; align-items: center; gap: 10px; }
.fnb-budget-title { color: white; font-size: 14px; font-weight: 600; flex: 1; font-family: 'Outfit', sans-serif; }
.fnb-budget-sub { color: rgba(255,255,255,0.45); font-size: 11px; font-family: 'Outfit', sans-serif; }
.fnb-budget-body { padding: 0 18px; }
.fnb-budget-item { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--fnb-border); font-size: 13px; gap: 16px; }
.fnb-budget-item:last-child { border-bottom: none; }
.fnb-budget-label { color: #666; }
.fnb-budget-value { font-weight: 600; color: var(--fnb-dark); font-family: 'Outfit', sans-serif; white-space: nowrap; }
.fnb-budget-total { margin: 0 18px; padding: 11px 0; border-top: 2px solid var(--fnb-dark); display: flex; justify-content: space-between; font-size: 14px; font-weight: 600; }
.fnb-budget-total-val { color: var(--fnb-orange); font-family: 'Outfit', sans-serif; }
.fnb-budget-note { padding: 9px 18px; font-size: 11px; color: #aaa; font-style: italic; border-top: 1px solid var(--fnb-border); font-family: 'Outfit', sans-serif; }

/* ── WHERE TO STAY ── */
.fnb-wts { border: 1px solid var(--fnb-border); margin: 28px 0; overflow: hidden; }
.fnb-wts-head { padding: 16px 18px; border-bottom: 1px solid var(--fnb-border); }
.fnb-wts-eyebrow { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 2px; color: var(--fnb-orange); margin-bottom: 4px; font-family: 'Outfit', sans-serif; }
.fnb-wts-title { font-size: 15px; font-weight: 600; color: var(--fnb-dark); margin: 0 0 2px; }
.fnb-wts-subtitle { font-size: 12px; color: #888; margin: 0; }
.fnb-wts-section-label { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.5px; padding: 8px 18px; border-bottom: 1px solid var(--fnb-border); display: flex; align-items: center; gap: 6px; font-family: 'Outfit', sans-serif; }
.fnb-tier-dot { width: 6px; height: 6px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.fnb-tier-budget { color: var(--fnb-green); background: var(--fnb-green-bg); } .fnb-tier-budget .fnb-tier-dot { background: var(--fnb-green); }
.fnb-tier-mid { color: var(--fnb-blue); background: var(--fnb-blue-bg); } .fnb-tier-mid .fnb-tier-dot { background: var(--fnb-blue); }
.fnb-tier-luxury { color: #993C1D; background: #fdf0ec; } .fnb-tier-luxury .fnb-tier-dot { background: #993C1D; }
.fnb-wts-item { display: flex; align-items: flex-start; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--fnb-border); }
.fnb-wts-num { font-size: 16px; color: var(--fnb-border); font-weight: 600; min-width: 24px; font-family: 'Prata', Georgia, serif; padding-top: 2px; }
.fnb-wts-item-body { flex: 1; }
.fnb-wts-item-name { font-size: 14px; font-weight: 600; color: var(--fnb-dark); margin-bottom: 2px; }
.fnb-wts-item-meta { font-size: 11px; color: var(--fnb-muted); margin-bottom: 5px; font-family: 'Outfit', sans-serif; }
.fnb-wts-item-desc { font-size: 13px; color: #666; line-height: 1.55; }
.fnb-wts-item-price { font-size: 12px; color: #888; margin-top: 5px; }
.fnb-wts-item-price strong { color: var(--fnb-dark); font-weight: 600; }
.fnb-wts-link { font-size: 12px; color: var(--fnb-orange); text-decoration: none; white-space: nowrap; padding-top: 3px; flex-shrink: 0; font-family: 'Outfit', sans-serif; font-weight: 500; }
.fnb-wts-grid { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--fnb-border); }
.fnb-wts-card { padding: 14px 16px; border-right: 1px solid var(--fnb-border); border-bottom: 1px solid var(--fnb-border); }
.fnb-wts-card:nth-child(2n) { border-right: none; }
.fnb-wts-card-tier { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; font-family: 'Outfit', sans-serif; }
.fnb-wts-card-tier.budget { color: var(--fnb-green); } .fnb-wts-card-tier.mid { color: var(--fnb-blue); } .fnb-wts-card-tier.luxury { color: #993C1D; }
.fnb-wts-card-name { font-size: 13px; font-weight: 600; color: var(--fnb-dark); margin-bottom: 2px; }
.fnb-wts-card-meta { font-size: 11px; color: var(--fnb-muted); margin-bottom: 6px; font-family: 'Outfit', sans-serif; }
.fnb-wts-card-desc { font-size: 12px; color: #666; line-height: 1.5; margin-bottom: 8px; }
.fnb-wts-card-price { font-size: 12px; color: #888; }
.fnb-wts-card-price strong { color: var(--fnb-dark); font-weight: 600; }
.fnb-wts-card-price a { color: var(--fnb-orange); text-decoration: none; font-weight: 500; }
.fnb-wts-cta { padding: 12px 18px; background: #fafafa; border-top: 1px solid var(--fnb-border); display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.fnb-wts-cta-text { font-size: 12px; color: #888; }
.fnb-wts-cta-btn { background: var(--fnb-orange); color: white; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; padding: 9px 16px; text-decoration: none; font-family: 'Outfit', sans-serif; }
.fnb-wts-cta-btn:hover { background: var(--fnb-dark); color: white; }
.fnb-wts-disclosure { padding: 7px 18px; font-size: 11px; color: #bbb; border-top: 1px solid var(--fnb-border); font-family: 'Outfit', sans-serif; }

/* ── TABLE ── */
.fnb-table-wrap { border: 1px solid var(--fnb-border); margin: 28px 0; overflow: hidden; }
.fnb-table-title { background: var(--fnb-dark); padding: 10px 14px; font-family: 'Outfit', sans-serif; font-size: 12px; font-weight: 500; color: white; display: flex; align-items: center; gap: 8px; }
.fnb-table { width: 100%; border-collapse: collapse !important; font-size: 13px; margin: 0 !important; border-spacing: 0 !important; }
.fnb-table thead tr { background: var(--fnb-dark); }
.fnb-table-wrap .fnb-table thead tr { background: #444; }
.fnb-table thead th { color: white; padding: 10px 14px; text-align: left; font-family: 'Outfit', sans-serif; font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.5px; white-space: nowrap; }
.fnb-table tbody tr { border-bottom: 1px solid var(--fnb-border); }
.fnb-table tbody tr:nth-child(even) { background: #fafafa; }
.fnb-table tbody td { padding: 9px 14px; color: var(--fnb-dark); vertical-align: top; line-height: 1.5; }
.fnb-table tbody td:first-child { font-family: 'Outfit', sans-serif; font-weight: 500; color: var(--fnb-orange); white-space: nowrap; }
.fnb-table-badge { display: inline-block; background: rgba(217,123,72,0.1); border: 1px solid rgba(217,123,72,0.3); color: var(--fnb-orange); font-size: 10px; font-family: 'Outfit', sans-serif; padding: 1px 7px; white-space: nowrap; }
.fnb-table-note { padding: 8px 14px; font-size: 11px; color: #aaa; font-style: italic; border-top: 1px solid var(--fnb-border); font-family: 'Outfit', sans-serif; }

/* ── WHO FOR ── */
.fnb-who { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--fnb-border); margin: 28px 0; overflow: hidden; }
.fnb-who-yes { border-right: 1px solid var(--fnb-border); }
.fnb-who-header { padding: 10px 16px; font-family: 'Outfit', sans-serif; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; border-bottom: 1px solid var(--fnb-border); display: flex; align-items: center; gap: 7px; }
.fnb-who-yes .fnb-who-header { background: var(--fnb-green-bg); color: #27500A; }
.fnb-who-no .fnb-who-header { background: var(--fnb-red-bg); color: var(--fnb-red); }
.fnb-who-list { list-style: none; margin: 0; padding: 0; }
.fnb-who-list li { padding: 8px 16px; font-size: 13px; border-bottom: 1px solid var(--fnb-border); color: var(--fnb-dark); line-height: 1.5; display: flex; align-items: flex-start; gap: 8px; }
.fnb-who-list li:last-child { border-bottom: none; }
.fnb-who-dot-yes { width: 6px; height: 6px; border-radius: 50%; background: var(--fnb-green); flex-shrink: 0; margin-top: 6px; }
.fnb-who-dot-no { width: 6px; height: 6px; border-radius: 50%; background: #9B2626; flex-shrink: 0; margin-top: 6px; }

/* ── ROUTE ── */
.fnb-route { border: 1px solid var(--fnb-border); margin: 28px 0; overflow: hidden; }
.fnb-route-header { background: var(--fnb-orange); padding: 12px 18px; display: flex; align-items: center; gap: 14px; }
.fnb-route-num { font-size: 28px; font-weight: 600; color: rgba(255,255,255,0.25); line-height: 1; font-family: 'Prata', Georgia, serif; }
.fnb-route-title { font-size: 14px; font-weight: 600; color: white; font-family: 'Outfit', sans-serif; }
.fnb-route-sub { font-size: 12px; color: rgba(255,255,255,0.75); margin-top: 2px; font-family: 'Outfit', sans-serif; }
.fnb-route-body { padding: 0 18px; }
.fnb-route-stop { display: flex; align-items: flex-start; gap: 10px; padding: 12px 0; border-bottom: 1px solid var(--fnb-border); }
.fnb-route-stop:last-child { border-bottom: none; }
.fnb-route-time { font-size: 11px; color: var(--fnb-muted); min-width: 40px; padding-top: 3px; font-family: 'Outfit', sans-serif; flex-shrink: 0; }
.fnb-route-dot-col { display: flex; flex-direction: column; align-items: center; padding-top: 5px; flex-shrink: 0; }
.fnb-route-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--fnb-orange); }
.fnb-route-line { width: 1px; background: var(--fnb-border); flex: 1; min-height: 16px; margin-top: 4px; }
.fnb-route-stop-name { font-size: 14px; font-weight: 600; color: var(--fnb-dark); margin-bottom: 2px; }
.fnb-route-stop-desc { font-size: 12px; color: #888; line-height: 1.5; }

/* ── TRAIN UPDATE ── */
.fnb-train-update { border: 1px solid var(--fnb-amber-border); background: var(--fnb-amber-bg); margin: 28px 0; overflow: hidden; }
.fnb-train-update-header { background: var(--fnb-amber); padding: 10px 16px; font-family: 'Outfit', sans-serif; font-size: 11px; font-weight: 500; color: white; text-transform: uppercase; letter-spacing: 0.4px; display: flex; align-items: center; gap: 6px; }
.fnb-train-update-body { padding: 13px 16px; font-size: 13px; color: var(--fnb-dark); line-height: 1.7; }
.fnb-train-update-body p { margin: 0 0 10px; }
.fnb-train-update-body p:last-child { margin: 0; }
.fnb-train-update-body a { color: var(--fnb-orange); font-weight: 500; text-decoration: none; }
.fnb-train-route { display: flex; align-items: center; gap: 6px; margin: 10px 0; flex-wrap: wrap; font-family: 'Outfit', sans-serif; font-size: 11px; }
.fnb-train-stop { padding: 3px 10px; color: white; background: var(--fnb-dark); }
.fnb-train-stop.new { background: var(--fnb-orange); }
.fnb-train-stop.old { background: #e8e8e8; color: #aaa; text-decoration: line-through; }
.fnb-train-arrow { color: var(--fnb-muted); font-size: 12px; }
.fnb-train-silver { background: var(--fnb-green-bg); border-left: 3px solid var(--fnb-green); padding: 9px 14px; margin-top: 10px; font-size: 13px; color: #27500A; }
.fnb-train-silver-label { font-family: 'Outfit', sans-serif; font-size: 10px; font-weight: 500; color: var(--fnb-green); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 3px; }

/* ── RESPONSIVE ── */
@media (max-width: 600px) {
    .fnb-who { grid-template-columns: 1fr; }
    .fnb-who-yes { border-right: none; border-bottom: 1px solid var(--fnb-border); }
    .fnb-wts-grid { grid-template-columns: 1fr; }
    .fnb-wts-card { border-right: none; }
    .fnb-table { font-size: 12px; }
    .fnb-table thead th, .fnb-table tbody td { padding: 7px 10px; }
}
