/* ===========================================================================
   Documentation page for the Flight Quote Widget.
   Reuses the design tokens, header (.hdr/.brand) and buttons (.cta) from
   styles.css; everything below is doc-specific layout.
   =========================================================================== */

.docnav{display:flex;align-items:center;gap:26px}
.docnav a{font-size:14px;font-weight:560;color:var(--muted);transition:.15s}
.docnav a:hover{color:var(--ink)}
@media(max-width:900px){.docnav{display:none}}

.pill{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:650;letter-spacing:.02em;
  color:var(--accent);background:var(--accent-soft);border:1px solid #ffe1d6;padding:5px 12px;border-radius:999px}
.pill::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* ---- Hero ---------------------------------------------------------------- */
.dhero{padding:64px 0 24px;background:
  radial-gradient(120% 120% at 90% -20%,#fff4ef 0%,transparent 45%),
  radial-gradient(90% 90% at 0% 0%,#f1f5ff 0%,transparent 40%)}
.dhero__grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.dhero h1{font-size:clamp(34px,5vw,56px);font-weight:720;letter-spacing:-.04em;margin:18px 0 0}
.dhero h1 em{font-style:normal;color:var(--accent)}
.dhero__sub{color:var(--muted);font-size:19px;margin-top:18px;max-width:30em}
.dhero__cta{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.dhero__cta .cta{width:auto}
.ticks{list-style:none;display:flex;flex-wrap:wrap;gap:8px 22px;padding:0;margin:26px 0 0}
.ticks li{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:540;color:var(--ink2)}
.ticks li::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;
  font-size:11px;font-weight:800;color:#fff;background:var(--accent);border-radius:50%}
.dhero__demo{position:relative}
.demoframe{background:#fff;border:1px solid var(--line2);border-radius:var(--r);box-shadow:var(--shadow);padding:8px}
.demoframe__bar{display:flex;align-items:center;gap:7px;padding:8px 10px 12px}
.demoframe__bar i{width:11px;height:11px;border-radius:50%;background:var(--line2)}
.demoframe__bar span{margin-left:8px;font-size:12px;color:var(--faint);font-weight:560}
@media(max-width:880px){.dhero__grid{grid-template-columns:1fr;gap:34px}.dhero{padding:40px 0 8px}}

/* ---- Sections ------------------------------------------------------------ */
.section{padding:64px 0;border-top:1px solid var(--line)}
.section__eyebrow{display:block;font-size:12px;font-weight:680;letter-spacing:.13em;color:var(--accent);text-transform:uppercase;margin:0 0 10px}
.section h2{font-size:clamp(26px,3.4vw,38px);font-weight:700;letter-spacing:-.03em}
.section__lead{color:var(--muted);font-size:18px;margin-top:14px;max-width:62ch}
.section__body{margin-top:34px}

/* ---- Code blocks --------------------------------------------------------- */
.codecard{border:1px solid #20283a;border-radius:var(--r-sm);overflow:hidden;background:#0d1320}
.codecard__bar{display:flex;align-items:center;justify-content:space-between;padding:9px 12px 9px 16px;
  background:#121a2b;border-bottom:1px solid #20283a}
.codecard__name{font-size:12.5px;font-weight:600;color:#aeb7c7;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.copy{display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;
  color:#cdd5e2;background:#1c2740;border:1px solid #2c3a57;border-radius:8px;padding:5px 11px;transition:.15s}
.copy:hover{background:#243454;color:#fff}
.copy.is-done{color:#7ee0a6;border-color:#2f6b4a}
.code{margin:0;padding:16px 18px;overflow-x:auto;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:13.5px;line-height:1.7;color:#e6ebf3;tab-size:2}
.code .t{color:#7fb0ff}      /* tag */
.code .a{color:#f5b97a}      /* attribute */
.code .s{color:#9ae6b4}      /* string */
.code .c{color:#5d6b85}      /* comment */
.code .k{color:#c9a6ff}      /* keyword */

/* ---- Config table -------------------------------------------------------- */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-sm)}
.tbl{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden}
@media(max-width:560px){.tbl{min-width:480px}}
.tbl th,.tbl td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);font-size:14.5px;vertical-align:top}
.tbl th{background:var(--bg2);font-weight:650;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.tbl tr:last-child td{border-bottom:0}
.tbl code{font-family:ui-monospace,Menlo,monospace;font-size:13px;font-weight:600;color:var(--accent);
  background:var(--accent-soft);padding:2px 7px;border-radius:6px}
.tbl .muted{color:var(--muted)}
.note{display:flex;gap:12px;margin-top:18px;padding:14px 16px;background:#f1f5ff;border:1px solid #dbe6ff;border-radius:var(--r-sm);font-size:14.5px;color:var(--ink2)}
.note b{color:var(--ink)}
.note::before{content:"ⓘ";color:#3b6fff;font-weight:800}

/* ---- Card grids ---------------------------------------------------------- */
.cards{display:grid;gap:18px}
.cards--3{grid-template-columns:repeat(3,1fr)}
.cards--2{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.cards--3,.cards--2{grid-template-columns:1fr}}
.pcard{border:1px solid var(--line);border-radius:var(--r);padding:22px;background:#fff;transition:.18s}
.pcard:hover{border-color:var(--line2);box-shadow:var(--shadow-sm)}
.pcard__ico{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;
  background:var(--bg2);border-radius:11px;margin-bottom:14px}
.pcard h3{font-size:17px;font-weight:660}
.pcard ol{margin:12px 0 0;padding-left:18px;color:var(--ink2);font-size:14px;line-height:1.65}
.pcard ol li{margin:5px 0}
.pcard p{color:var(--muted);font-size:14px;margin-top:8px}
.pcard code{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;background:var(--bg2);padding:1px 6px;border-radius:5px;color:var(--ink2)}

/* ---- How-it-works steps -------------------------------------------------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;counter-reset:s}
@media(max-width:820px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:24px 22px;border:1px solid var(--line);border-radius:var(--r);background:#fff}
.step__n{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;
  background:var(--ink);color:#fff;font-weight:700;font-size:14px;margin-bottom:12px}
.step h3{font-size:16.5px;font-weight:650}
.step p{color:var(--muted);font-size:14px;margin-top:7px}

/* ---- Playground ---------------------------------------------------------- */
.pg{margin-top:34px}
.pg__controls{border:1px solid var(--line);border-radius:var(--r);padding:20px;background:var(--bg2);min-width:0}
.pg__fields{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:700px){.pg__fields{grid-template-columns:1fr}}
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;font-weight:650;color:var(--ink2);margin-bottom:6px}
.field input[type=text]{width:100%;border:1px solid var(--line2);border-radius:9px;padding:10px 12px;font:inherit;font-size:14px;background:#fff}
.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--ring)}
.swatches{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.swatch{width:30px;height:30px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line2);cursor:pointer;transition:.12s}
.swatch:hover{transform:scale(1.08)}
.swatch.is-on{box-shadow:0 0 0 2px var(--ink)}
.swatch--custom{position:relative;overflow:hidden;background:conic-gradient(from 0deg,#ff5a1f,#0a66ff,#16a34a,#a855f7,#ff5a1f)}
.swatch--custom input{position:absolute;inset:-6px;opacity:0;cursor:pointer}

/* Device-size switcher + animated viewport */
.pg__stage{margin-top:22px}
.devbar{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.devbtn{display:inline-flex;align-items:center;gap:7px;font:inherit;font-size:13px;font-weight:600;cursor:pointer;
  color:var(--ink2);background:#fff;border:1px solid var(--line2);border-radius:999px;padding:7px 14px;transition:.15s}
.devbtn:hover{border-color:var(--ink)}
.devbtn.is-on{background:var(--ink);color:#fff;border-color:var(--ink)}
.devbar__w{margin-left:auto;font-size:12.5px;color:var(--faint);font-weight:600;font-variant-numeric:tabular-nums}
/* devscale = the on-screen footprint (centered, animated); devport renders at the
   real device width and is transform-scaled to fit, so Desktop always shows the
   desktop layout even when the container is narrower than the device. */
.devscale{margin:0 auto;overflow:hidden;transition:width .45s cubic-bezier(.4,0,.2,1),height .45s cubic-bezier(.4,0,.2,1)}
.devport{transform-origin:top left;transition:transform .45s cubic-bezier(.4,0,.2,1)}
.devport .demoframe{box-shadow:var(--shadow-sm)}

/* ---- Footer -------------------------------------------------------------- */
.dftr{background:var(--ink);color:#cfd5df;padding:46px 0;margin-top:8px}
.dftr__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.dftr__nav{display:flex;gap:22px;flex-wrap:wrap}
.dftr__nav a{color:#cfd5df;font-size:14px}
.dftr__nav a:hover{color:#fff}
.dftr__small{color:#7b8494;font-size:13px;margin-top:10px;max-width:52ch}

/* ---- Toast --------------------------------------------------------------- */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);z-index:200;
  background:var(--ink);color:#fff;padding:13px 20px;border-radius:12px;font-size:14px;font-weight:560;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s}
.toast.is-on{opacity:1;transform:translateX(-50%) translateY(0)}
.toast b{color:#ffd2c2}

.iframe-auto{width:100%;border:0;display:block;min-height:300px;overflow:hidden;transition:height .3s ease}

/* ---- Wordmark (replaces the old image logo) ------------------------------ */
.wordmark{display:inline-flex;align-items:center;gap:9px;font-weight:730;font-size:19px;letter-spacing:-.03em;color:var(--ink)}
.wordmark b{font-weight:730;color:var(--accent)}
.wordmark__mark{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;
  background:var(--accent);color:#fff;font-size:15px;transform:rotate(0deg)}
.wordmark--ftr{color:#fff;font-size:18px}
.wordmark--ftr b{color:#ff9d7a}
