/* London Free Guide — First Time page ("Start Here").
   Editorial + the 3-tap planner. Built on tokens.css + home.css.
   Text-forward on purpose: distinct from the photo feeds, and the kind of
   real, public copy that ranks and gets cited. */

/* ---------- hero ---------- */
.ft-hero { position: relative; background: var(--lfg-pure-black); overflow: hidden; }
[data-theme="light"] .ft-hero { background: linear-gradient(180deg, #efe8dc 0%, #f4f0ea 100%); border-bottom: 1px solid var(--lfg-white-08); }
[data-theme="light"] .ft-hero::before { background: radial-gradient(circle, color-mix(in srgb, var(--lfg-accent) 14%, transparent) 0%, transparent 68%); }
[data-theme="light"] .ft-eyebrow { color: var(--lfg-white); }
[data-theme="light"] .ft-title { color: var(--lfg-white); }
[data-theme="light"] .ft-sub { color: var(--lfg-white-70); }
[data-theme="light"] .ft-btn-lg.ghost { border-color: rgba(28,20,13,.3); color: var(--lfg-white); }
[data-theme="light"] .ft-btn-lg.ghost:hover { border-color: var(--lfg-white); background: rgba(28,20,13,.05); }
.ft-hero::before {
  content: ""; position: absolute; top: -30%; right: -10%; width: 540px; height: 540px;
  border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, color-mix(in srgb, var(--lfg-accent) 32%, transparent) 0%, transparent 68%);
}
.ft-hero-inner { position: relative; padding: 56px 0 48px; }
@media (min-width: 860px) {
  .ft-hero-inner { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: start; }
  .ft-hero-r .ft-sub { margin-bottom: 24px; }
}
.ft-eyebrow { font-family: var(--lfg-font-hand); color: #fff; font-size: 2rem; line-height: 1; display: block; margin-bottom: 10px; }
.ft-title {
  font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase;
  color: #fff; line-height: 1; letter-spacing: .005em; max-width: 11ch;
  font-size: clamp(2.3rem, 5.5vw, 4rem); margin: 0 0 1.6rem;
}
.ft-title .r { color: var(--lfg-accent); }
.ft-sub { color: rgba(255,255,255,.82); font-size: 1.08rem; line-height: 1.55; max-width: 46ch; margin-bottom: 26px; }
.ft-hero-cta { display: flex; flex-wrap: wrap; gap: 12px; }
.ft-btn-lg { font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .03em; font-size: .82rem; padding: .85rem 1.4rem; border-radius: var(--lfg-radius-pill); display: inline-flex; align-items: center; gap: 8px; transition: transform .15s, background .15s, border-color .15s; }
.ft-btn-lg.solid { background: var(--lfg-accent); color: #fff; }
.ft-btn-lg.solid:hover { transform: translateY(-2px); }
.ft-btn-lg.ghost { border: 1.5px solid rgba(255,255,255,.35); color: #fff; }
.ft-btn-lg.ghost:hover { border-color: #fff; background: rgba(255,255,255,.06); }

/* ---------- in-page jump chips ---------- */
.ft-jump { position: sticky; top: 58px; z-index: 30; background: color-mix(in srgb, var(--lfg-black) 88%, transparent); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--lfg-white-08); }
.ft-jump-row { display: flex; gap: 8px; overflow-x: auto; padding: 11px 0; scrollbar-width: none; }
.ft-jump-row::-webkit-scrollbar { display: none; }
.ft-jump a { flex-shrink: 0; font-weight: 600; font-size: .76rem; color: var(--lfg-white-50); padding: .42em .8em; border-radius: var(--lfg-radius-pill); border: 1px solid transparent; white-space: nowrap; transition: color .15s, border-color .15s, background .15s; }
.ft-jump a:hover { color: var(--lfg-white); background: var(--lfg-white-08); }

/* ---------- generic section frame ---------- */
.ft-sec { padding: 46px 0 8px; scroll-margin-top: 120px; }
.ft-sec-head { margin-bottom: 26px; }
.ft-divider { width: 64px; height: 4px; background: var(--lfg-accent); border-radius: 2px; margin-bottom: 14px; }
.ft-kicker { font-family: var(--lfg-font-hand); font-size: 1.5rem; color: var(--lfg-white); line-height: 1; display: block; margin-bottom: 4px; }
.ft-h { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: var(--lfg-text-h2); line-height: .94; text-wrap: balance; }
.ft-lede { color: var(--lfg-white-70); font-size: 1.02rem; line-height: 1.6; max-width: 60ch; margin-top: 12px; text-wrap: pretty; }

/* ---------- the canon (numbered editorial cards, no photos) ---------- */
.ft-canon { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 640px) { .ft-canon { grid-template-columns: 1fr 1fr; gap: 14px; } }
@media (min-width: 980px) { .ft-canon { grid-template-columns: 1fr 1fr 1fr; } }
.ft-card { display: flex; gap: 16px; background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; padding: 18px; transition: border-color .15s, transform .15s; min-width: 0; }
[data-theme="light"] .ft-card { background: #fff; }
a.ft-card:hover { border-color: var(--lfg-white-15); transform: translateY(-2px); }
.ft-num { flex-shrink: 0; font-family: var(--lfg-font-head); font-weight: 700; font-size: 1.9rem; line-height: 1; color: var(--lfg-accent); width: 1.4em; }
.ft-card-body { min-width: 0; flex: 1; }
.ft-card-name { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.18rem; line-height: 1; margin-bottom: 8px; text-wrap: balance; }
.ft-card-loc { display: flex; align-items: center; gap: 6px; font-weight: 500; font-size: .76rem; color: var(--lfg-white-50); margin-bottom: 9px; flex-wrap: wrap; }
.ft-card-loc .pin { color: var(--lfg-accent); }
.ft-card-blurb { color: var(--lfg-white-70); font-size: .88rem; line-height: 1.5; text-wrap: pretty; }
.ft-tag { display: inline-flex; align-items: center; gap: 5px; margin-top: 11px; font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; font-size: .58rem; padding: .36em .62em; border-radius: var(--lfg-radius-pill); background: var(--lfg-accent); color: #fff; }
.ft-tag.note { display: inline-block; background: var(--lfg-white-08); color: var(--lfg-white-70); text-transform: none; letter-spacing: 0; font-weight: 500; font-size: .68rem; }
.ft-card-go { display: inline-block; margin-top: 11px; font-weight: 700; font-size: .68rem; text-transform: uppercase; letter-spacing: .04em; color: var(--lfg-accent); white-space: nowrap; }
a.ft-card:hover .ft-card-go { text-decoration: underline; text-underline-offset: 3px; }

/* ---------- sample free day (timeline) ---------- */
.ft-itin { display: flex; flex-direction: column; gap: 0; border-left: 2px solid var(--lfg-white-15); margin-left: 6px; }
.ft-itin-block { position: relative; padding: 0 0 30px 28px; }
.ft-itin-block:last-child { padding-bottom: 4px; }
.ft-itin-dot { position: absolute; left: -11px; top: 2px; width: 20px; height: 20px; border-radius: 50%; background: var(--lfg-accent); display: flex; align-items: center; justify-content: center; font-size: .62rem; }
.ft-itin-part { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.28rem; line-height: 1; }
.ft-itin-time { font-weight: 600; font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; color: var(--lfg-accent); margin: 6px 0 12px; }
.ft-stop { padding: 11px 0; border-top: 1px solid var(--lfg-white-08); }
.ft-stop:first-of-type { border-top: none; padding-top: 0; }
.ft-stop-name { font-weight: 700; font-size: .96rem; margin-bottom: 4px; }
.ft-stop-note { color: var(--lfg-white-70); font-size: .86rem; line-height: 1.5; text-wrap: pretty; }
.ft-itin-foot { margin-top: 2px; padding-left: 28px; }
.ft-itin-foot .ft-maps { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: .74rem; text-transform: uppercase; letter-spacing: .03em; color: #fff; background: var(--lfg-accent); padding: .7rem 1.15rem; border-radius: var(--lfg-radius-pill); transition: transform .15s; }
.ft-itin-foot .ft-maps:hover { transform: translateY(-2px); }

/* ---------- how London works (3 cards) ---------- */
.ft-grid3 { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 760px) { .ft-grid3 { grid-template-columns: 1fr 1fr 1fr; } }
.ft-howcard { background: #141414; border: 1px solid var(--lfg-white-08); border-top: 3px solid var(--lfg-accent); border-radius: 14px; padding: 22px 20px; }
[data-theme="light"] .ft-howcard { background: #fff; }
.ft-howcard h3 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.22rem; line-height: 1; margin-bottom: 11px; }
.ft-howcard p { color: var(--lfg-white-70); font-size: .9rem; line-height: 1.55; text-wrap: pretty; }

/* ---------- what's free vs overpay (compare rows) ---------- */
.ft-overpay { display: flex; flex-direction: column; gap: 12px; }
.ft-op-row { display: grid; grid-template-columns: 1fr; gap: 0; background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; overflow: hidden; }
[data-theme="light"] .ft-op-row { background: #fff; }
@media (min-width: 680px) { .ft-op-row { grid-template-columns: 1fr 44px 1.3fr; align-items: stretch; } }
.ft-op-paid { padding: 16px 18px; }
.ft-op-label { font-weight: 600; font-size: .62rem; text-transform: uppercase; letter-spacing: .07em; color: var(--lfg-white-50); margin-bottom: 6px; }
.ft-op-paid .ft-op-name { font-weight: 600; font-size: 1rem; color: var(--lfg-white-90); text-decoration: line-through; text-decoration-color: var(--lfg-white-30); }
.ft-op-price { font-family: var(--lfg-font-head); font-weight: 700; color: var(--lfg-white-50); font-size: .94rem; margin-top: 3px; }
.ft-op-arrow { display: flex; align-items: center; justify-content: center; color: var(--lfg-accent); font-size: 1.2rem; background: var(--lfg-white-08); }
@media (max-width: 679px) { .ft-op-arrow { display: none; } }
.ft-op-free { padding: 16px 18px; border-left: 3px solid var(--lfg-accent); }
@media (max-width: 679px) { .ft-op-free { border-left: none; border-top: 1px solid var(--lfg-white-08); } }
.ft-op-free .ft-op-name { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.18rem; line-height: 1; margin-bottom: 5px; }
.ft-op-why { color: var(--lfg-white-70); font-size: .84rem; line-height: 1.45; }
.ft-op-badge { display: inline-block; margin-left: 8px; font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .04em; font-size: .54rem; padding: .3em .55em; border-radius: var(--lfg-radius-pill); background: #2ECC40; color: #06210b; vertical-align: middle; }

/* ---------- mistakes ---------- */
.ft-mistakes { display: grid; grid-template-columns: 1fr; gap: 10px; }
@media (min-width: 720px) { .ft-mistakes { grid-template-columns: 1fr 1fr; gap: 12px 22px; } }
.ft-mistake { display: flex; gap: 13px; align-items: flex-start; padding: 14px 16px; background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 12px; }
[data-theme="light"] .ft-mistake { background: #fff; }
.ft-x { flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%; background: color-mix(in srgb, var(--lfg-accent) 18%, transparent); color: var(--lfg-accent); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .82rem; margin-top: 1px; }
.ft-mistake p { color: var(--lfg-white-90); font-size: .9rem; line-height: 1.5; text-wrap: pretty; }

/* ---------- neighbourhoods ---------- */
.ft-hoods { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 600px) { .ft-hoods { grid-template-columns: 1fr 1fr; gap: 14px; } }
@media (min-width: 920px) { .ft-hoods { grid-template-columns: 1fr 1fr 1fr 1fr; } }
.ft-hood { background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; padding: 18px; }
[data-theme="light"] .ft-hood { background: #fff; }
.ft-hood h3 { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.06rem; line-height: 1.18; margin-bottom: 11px; text-wrap: balance; }
.ft-hood p { color: var(--lfg-white-70); font-size: .85rem; line-height: 1.5; text-wrap: pretty; }

/* ---------- first-timer FAQ (accordion) ---------- */
.ft-faq { display: flex; flex-direction: column; gap: 10px; max-width: 760px; }
.ft-faq-item { background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 12px; overflow: hidden; transition: border-color .15s; }
[data-theme="light"] .ft-faq-item { background: #fff; }
.ft-faq-item.open { border-color: var(--lfg-white-15); }
.ft-faq-q { display: flex; align-items: center; justify-content: space-between; gap: 16px; width: 100%; text-align: left; padding: 16px 18px; font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.02rem; line-height: 1.1; color: var(--lfg-white); }
.ft-faq-q:hover { color: var(--lfg-accent); }
.ft-faq-ico { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: var(--lfg-white-08); color: var(--lfg-accent); display: inline-flex; align-items: center; justify-content: center; font-size: 1.1rem; font-weight: 700; line-height: 1; }
.ft-faq-item.open .ft-faq-ico { background: var(--lfg-accent); color: #fff; }
.ft-faq-a { padding: 0 18px 18px; color: var(--lfg-white-70); font-size: .95rem; line-height: 1.6; max-width: 64ch; text-wrap: pretty; }

/* ---------- getting in from the airport ---------- */
.ft-air-label { font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; font-size: .72rem; color: var(--lfg-white-50); margin: 4px 0 14px; }
.ft-air-grid { display: grid; grid-template-columns: 1fr; gap: 14px; margin-bottom: 30px; }
@media (min-width: 760px) { .ft-air-grid { grid-template-columns: 1fr 1fr 1fr; } }
.ft-air-card { position: relative; background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; padding: 20px 18px; }
[data-theme="light"] .ft-air-card { background: #fff; }
.ft-air-card.best { border-color: color-mix(in srgb, var(--lfg-accent) 55%, transparent); box-shadow: 0 0 0 1px color-mix(in srgb, var(--lfg-accent) 30%, transparent); }
.ft-air-flag { white-space: nowrap; position: absolute; top: -10px; left: 16px; font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; font-size: .56rem; padding: .4em .7em; border-radius: var(--lfg-radius-pill); background: var(--lfg-accent); color: #fff; }
.ft-air-tag { display: inline-block; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; font-size: .58rem; color: var(--lfg-white-50); margin-bottom: 8px; }
.ft-air-name { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.28rem; line-height: 1; margin-bottom: 12px; }
.ft-air-stats { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--lfg-white-08); }
.ft-air-price { white-space: nowrap; font-family: var(--lfg-font-head); font-weight: 700; font-size: 1.5rem; line-height: 1; color: var(--lfg-accent); }
.ft-air-time { font-weight: 500; font-size: .8rem; color: var(--lfg-white-50); margin-left: 2px; }
.ft-air-d { color: var(--lfg-white-70); font-size: .86rem; line-height: 1.5; text-wrap: pretty; }

.ft-air-others { display: grid; grid-template-columns: 1fr; gap: 10px; }
@media (min-width: 720px) { .ft-air-others { grid-template-columns: 1fr 1fr; gap: 12px; } }
.ft-air-row { display: flex; gap: 14px; align-items: flex-start; background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 12px; padding: 15px 16px; }
[data-theme="light"] .ft-air-row { background: #fff; }
.ft-air-port { flex-shrink: 0; width: 86px; font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.02rem; line-height: 1.05; color: var(--lfg-white); }
.ft-air-route { flex: 1; min-width: 0; }
.ft-air-cheap { font-weight: 500; font-size: .9rem; color: var(--lfg-white-90); line-height: 1.4; margin-bottom: 4px; }
.ft-air-take { font-weight: 700; text-transform: uppercase; letter-spacing: .04em; font-size: .62rem; color: var(--lfg-accent); margin-right: 2px; }
.ft-air-from { font-weight: 700; font-size: .82rem; color: var(--lfg-accent); white-space: nowrap; }
.ft-air-to { font-size: .8rem; color: var(--lfg-white-70); margin-bottom: 5px; }
.ft-air-skip { font-size: .76rem; color: var(--lfg-white-50); font-style: italic; }
.ft-air-note { font-size: .76rem; color: var(--lfg-white-30); margin: 14px 0 6px; }

.ft-air-dd { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 26px; }
@media (min-width: 720px) { .ft-air-dd { grid-template-columns: 1fr 1fr; gap: 20px; } }
.ft-air-do, .ft-air-dont { background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; padding: 18px; }
[data-theme="light"] .ft-air-do, [data-theme="light"] .ft-air-dont { background: #fff; }
.ft-air-do { border-top: 3px solid #2ECC40; }
.ft-air-dont { border-top: 3px solid var(--lfg-accent); }
.ft-air-ddh { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.1rem; line-height: 1; margin-bottom: 14px; }
.ft-dd-item { display: flex; gap: 11px; align-items: flex-start; }
.ft-dd-item + .ft-dd-item { margin-top: 12px; }
.ft-dd-item p { color: var(--lfg-white-90); font-size: .86rem; line-height: 1.5; text-wrap: pretty; }
.ft-tick { flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%; background: rgba(46,204,64,.16); color: #2ECC40; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .76rem; margin-top: 1px; }
[data-theme="light"] .ft-tick { color: #1c7a2e; }

/* ---------- where to stay ---------- */
.ft-stay-legend { font-weight: 500; font-size: .8rem; color: var(--lfg-white-50); margin-bottom: 20px; }
.ft-stay-grid { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 640px) { .ft-stay-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .ft-stay-grid { grid-template-columns: 1fr 1fr 1fr; } }
.ft-stay-card { display: flex; flex-direction: column; background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; padding: 18px; }
[data-theme="light"] .ft-stay-card { background: #fff; }
.ft-stay-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.ft-stay-tag { white-space: nowrap; font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .05em; font-size: .58rem; padding: .38em .7em; border-radius: var(--lfg-radius-pill); background: var(--lfg-accent); color: #fff; }
.ft-price { display: inline-flex; gap: 1px; }
.ft-pound { font-family: var(--lfg-font-head); font-weight: 700; font-size: 1rem; color: var(--lfg-white-15); line-height: 1; }
.ft-pound.on { color: var(--lfg-white-90); }
.ft-stay-name { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.24rem; line-height: 1; margin-bottom: 9px; text-wrap: balance; }
.ft-stay-meta { display: flex; flex-wrap: wrap; align-items: baseline; gap: 4px 9px; margin-bottom: 11px; }
.ft-stay-zone { font-weight: 700; font-size: .6rem; text-transform: uppercase; letter-spacing: .05em; color: var(--lfg-accent); background: color-mix(in srgb, var(--lfg-accent) 14%, transparent); padding: .3em .55em; border-radius: 5px; }
.ft-stay-lines { font-weight: 500; font-size: .74rem; color: var(--lfg-white-50); }
.ft-stay-blurb { color: var(--lfg-white-70); font-size: .86rem; line-height: 1.5; text-wrap: pretty; margin-bottom: 12px; }
.ft-stay-near { display: flex; gap: 6px; font-weight: 500; font-size: .78rem; color: var(--lfg-white-90); line-height: 1.4; margin-bottom: 13px; }
.ft-stay-near .pin { color: var(--lfg-accent); flex-shrink: 0; }
.ft-stay-link { margin-top: auto; align-self: flex-start; font-weight: 700; font-size: .68rem; text-transform: uppercase; letter-spacing: .04em; color: var(--lfg-accent); }
.ft-stay-link:hover { text-decoration: underline; text-underline-offset: 3px; }

.ft-stay-split { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 16px; }
@media (min-width: 860px) { .ft-stay-split { grid-template-columns: 1.3fr 1fr; gap: 22px; } }
.ft-stay-subh { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.1rem; line-height: 1; margin-bottom: 14px; }
.ft-stay-typerow { display: grid; grid-template-columns: 1fr; gap: 10px; }
@media (min-width: 520px) { .ft-stay-typerow { grid-template-columns: 1fr 1fr 1fr; } }
.ft-stay-type { background: #141414; border: 1px solid var(--lfg-white-08); border-top: 3px solid var(--lfg-accent); border-radius: 12px; padding: 14px 15px; }
[data-theme="light"] .ft-stay-type { background: #fff; }
.ft-stay-type-t { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1rem; margin-bottom: 7px; }
.ft-stay-type p { color: var(--lfg-white-70); font-size: .82rem; line-height: 1.5; text-wrap: pretty; }
.ft-stay-avoid { background: #141414; border: 1px solid var(--lfg-white-08); border-radius: 14px; padding: 18px; }
[data-theme="light"] .ft-stay-avoid { background: #fff; }
.ft-avoid-item { display: flex; gap: 12px; align-items: flex-start; }
.ft-avoid-item + .ft-avoid-item { margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--lfg-white-08); }
.ft-avoid-t { font-weight: 700; font-size: .9rem; margin-bottom: 4px; }
.ft-avoid-item p { color: var(--lfg-white-70); font-size: .82rem; line-height: 1.5; text-wrap: pretty; }

/* ===================== the 3-tap planner ===================== */
.ft-planner-sec { padding: 50px 0 12px; scroll-margin-top: 120px; }
.ft-planner { background: var(--lfg-pure-black); border: 1px solid var(--lfg-white-15); border-radius: 20px; padding: 30px 26px; position: relative; overflow: hidden; }
[data-theme="light"] .ft-planner { background: #fff; border-color: var(--lfg-white-15); }
.ft-planner::before { content: ""; position: absolute; top: -40%; left: -8%; width: 380px; height: 380px; border-radius: 50%; background: radial-gradient(circle, color-mix(in srgb, var(--lfg-accent) 24%, transparent) 0%, transparent 70%); pointer-events: none; }
.ft-planner-inner { position: relative; }
.ft-planner-eyebrow { font-family: var(--lfg-font-hand); font-size: 1.5rem; color: var(--lfg-white); display: block; margin-bottom: 4px; }
.ft-planner-h { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: clamp(1.6rem, 3.4vw, 2.3rem); line-height: .96; margin-bottom: 6px; }
.ft-planner-sub { color: var(--lfg-white-70); font-size: .96rem; margin-bottom: 26px; max-width: 48ch; }

.ft-q { margin-bottom: 22px; }
.ft-q-label { display: flex; align-items: baseline; gap: 10px; margin-bottom: 12px; }
.ft-q-n { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: var(--lfg-accent); color: #fff; font-family: var(--lfg-font-head); font-weight: 700; font-size: .92rem; display: inline-flex; align-items: center; justify-content: center; }
.ft-q-t { font-weight: 600; font-size: .96rem; color: var(--lfg-white-90); }
.ft-opts { display: flex; flex-wrap: wrap; gap: 9px; padding-left: 36px; }
.ft-opt { font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .02em; font-size: .76rem; padding: .62em 1.05em; border-radius: var(--lfg-radius-pill); background: var(--lfg-white-08); color: var(--lfg-white-70); border: 1.5px solid transparent; transition: background .15s, color .15s, border-color .15s, transform .12s; }
.ft-opt:hover { color: var(--lfg-white); transform: translateY(-1px); }
.ft-opt.on { background: var(--lfg-accent); color: #fff; border-color: var(--lfg-accent); }
@media (max-width: 560px) { .ft-opts { padding-left: 0; } }

.ft-plan-actions { display: flex; flex-wrap: wrap; gap: 11px; align-items: center; padding-left: 36px; margin-top: 4px; }
@media (max-width: 560px) { .ft-plan-actions { padding-left: 0; } }
.ft-build { font-family: var(--lfg-font-body); font-weight: 700; text-transform: uppercase; letter-spacing: .03em; font-size: .82rem; background: var(--lfg-accent); color: #fff; padding: .82rem 1.5rem; border-radius: var(--lfg-radius-pill); transition: transform .15s, opacity .15s; }
.ft-build:hover { transform: translateY(-2px); }
.ft-build:disabled { opacity: .4; cursor: default; transform: none; }
.ft-reset { font-weight: 600; font-size: .8rem; color: var(--lfg-white-50); text-decoration: underline; text-underline-offset: 3px; }
.ft-reset:hover { color: var(--lfg-white); }

/* the generated plan */
.ft-result { margin-top: 26px; border-top: 1px solid var(--lfg-white-15); padding-top: 24px; }
.ft-result-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.ft-result-title { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.3rem; line-height: 1; }
.ft-result-title .r { color: var(--lfg-accent); }
.ft-result-meta { font-weight: 500; font-size: .82rem; color: var(--lfg-white-50); }
.ft-plan-list { display: flex; flex-direction: column; gap: 10px; }
.ft-plan-row { display: flex; gap: 15px; align-items: flex-start; background: var(--lfg-white-08); border-radius: 12px; padding: 14px 15px; }
.ft-plan-rank { flex-shrink: 0; font-family: var(--lfg-font-head); font-weight: 700; font-size: 1.5rem; line-height: 1; color: var(--lfg-accent); width: 1.2em; text-align: center; }
.ft-plan-body { min-width: 0; flex: 1; }
.ft-plan-name { font-family: var(--lfg-font-head); font-weight: 700; text-transform: uppercase; font-size: 1.12rem; line-height: 1; margin-bottom: 6px; }
.ft-plan-loc { display: flex; align-items: center; gap: 6px; font-weight: 500; font-size: .74rem; color: var(--lfg-white-50); margin-bottom: 7px; flex-wrap: wrap; }
.ft-plan-loc .pin { color: var(--lfg-accent); }
.ft-plan-blurb { color: var(--lfg-white-70); font-size: .84rem; line-height: 1.45; text-wrap: pretty; }
.ft-plan-link { display: inline-block; margin-top: 7px; font-weight: 700; font-size: .66rem; text-transform: uppercase; letter-spacing: .04em; color: var(--lfg-accent); }
.ft-plan-link:hover { text-decoration: underline; text-underline-offset: 3px; }

.ft-result-cta { display: flex; flex-wrap: wrap; gap: 11px; margin-top: 18px; }
.ft-result-cta .ft-rbtn { display: inline-flex; align-items: center; gap: 8px; font-weight: 700; font-size: .76rem; text-transform: uppercase; letter-spacing: .03em; padding: .72rem 1.2rem; border-radius: var(--lfg-radius-pill); transition: transform .15s, border-color .15s, background .15s; }
.ft-rbtn.solid { background: var(--lfg-accent); color: #fff; }
.ft-rbtn.solid:hover { transform: translateY(-2px); }
.ft-rbtn.ghost { border: 1.5px solid var(--lfg-white-30); color: var(--lfg-white-90); }
.ft-rbtn.ghost:hover { border-color: var(--lfg-white); }
.ft-plan-empty { color: var(--lfg-white-70); font-size: .92rem; line-height: 1.5; padding: 4px 0; }
.ft-plan-empty a { color: var(--lfg-accent); font-weight: 600; }

/* ---------- closing back link ---------- */
.ft-foot-nav { padding: 14px 0 34px; }
.ft-back-link { display: inline-flex; align-items: center; gap: 8px; font-weight: 600; font-size: .9rem; color: var(--lfg-white-70); }
.ft-back-link:hover { color: var(--lfg-white); }
