/* =========================================================
   destiny.css - Destiny app styles (mox framework + search widget)
   ========================================================= */

/* =========================================================
   Theme tokens
   ========================================================= */
:root{
  --bg:#0b1020;
  --card:#101a33;
  --muted:#c8d3ef;
  --text:#eaf0ff;
  --line:rgba(255,255,255,.12);
  --btn:#2563eb;
  --btn-hover:#1d4ed8;
  --ok:#2dd4bf;
  --err:#fb7185;

  --shadow: 0 16px 40px rgba(0,0,0,.35);
  --radius:14px;
  --radius-sm: 12px;
  --radius-lg: 18px;
  --focus-ring: 2px solid rgba(37,99,235,.6);
  --surface-1: rgba(0,0,0,.18);
  --surface-2: rgba(0,0,0,.16);
  --surface-3: rgba(0,0,0,.12);
  --menu-bg: rgba(16,26,51,.98);
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --lt-bg: #f8f9fc;
  --lt-bg-subtle: #f1f5f9;
  --lt-bg-code: #e8ecf4;
  --lt-text: #1a1a2e;
  --lt-text-heading: #0f172a;
  --lt-text-muted: #64748b;
  --lt-line: #e2e8f0;
  --lt-line-dark: #d1d9e6;
  --lt-link: #2563eb;
  --lt-link-hover: #1d4ed8;
}

/* =========================================================
   Base
   ========================================================= */
*{ box-sizing:border-box; }
.hidden{ display:none !important; }

body{
  margin:0;
  font-family: 'Open Sans', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(37,99,235,.35), transparent 60%),
    radial-gradient(900px 500px at 90% 10%, rgba(45,212,191,.18), transparent 55%),
    var(--bg);
  min-height:100vh;
  display:flex;
  flex-direction: column;
  align-items:center;
  justify-content:flex-start;
  padding:24px;
}

.wrap{
  width:min(900px, 100%);
  min-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
  position: relative;
}

#appBlurWrap{
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
}

#appBlurWrap > main{
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* =========================================================
   Locked / blur
   ========================================================= */
body.auth-locked #appBlurWrap,
body.modal-open #appBlurWrap{
  filter: blur(5px);
  opacity: 0.70;
  transform: translateZ(0);
  pointer-events: none;
  user-select: none;
}

#topChrome{
  position: relative;
  z-index: 120;
  pointer-events: auto;
  filter: none;
  opacity: 1;
}
#topChrome #acctMenu{ position: absolute; z-index: 130; }

/* =========================================================
   Typography
   ========================================================= */
.title{
  font-size:22px;
  font-weight:700;
  letter-spacing:.2px;
  margin:0;
}
.subtitle{
  margin:6px 0 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.3;
}

/* =========================================================
   Topbar
   ========================================================= */
.app-topbar{
  position: relative;
  z-index: 120;
  margin: 0 0 14px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.app-topbar .topbar-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.app-topbar .title,
.app-topbar .subtitle{
  text-shadow: 0 1px 2px rgba(0,0,0,.45);
  overflow-wrap:anywhere;
}
.app-topbar #appChrome{ flex: 1 1 auto; min-width: 0; }
.app-topbar #topChrome{ flex: 0 0 auto; }
.topbar{ display:flex; justify-content:flex-end; position:relative; }

/* =========================================================
   Card
   ========================================================= */
.card{
  background: var(--lt-bg);
  border:1px solid var(--lt-line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.card-inner{
  padding:18px;
  color: var(--lt-text);
}
.card .title{ color: var(--lt-text-heading); }
.card .subtitle{ color: var(--lt-text-muted); }
.card a:not(.btn){ color: var(--lt-link); }
.card a:not(.btn):hover{ color: var(--lt-link-hover); }

/* =========================================================
   Buttons + spinner
   ========================================================= */
.btn{
  border:0;
  border-radius: var(--radius-sm);
  padding:14px 16px;
  font-size:15px;
  font-weight:650;
  cursor:pointer;
  color:white;
  background:linear-gradient(180deg, var(--btn), rgba(37,99,235,.85));
  min-width:170px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  box-shadow: 0 10px 22px rgba(37,99,235,.3);
  text-decoration: none;
}
.btn:hover{
  background:linear-gradient(180deg, var(--btn-hover), rgba(29,78,216,.9));
}
.btn:disabled{ opacity:.6; cursor:not-allowed; box-shadow:none; }
.btn.secondary{
  background: #fff;
  border:1px solid var(--lt-line-dark);
  color: var(--lt-text);
  box-shadow:none;
  min-width:auto;
  padding:12px 14px;
}
.btn.secondary:hover{
  background: var(--lt-bg-subtle);
  border-color: var(--lt-text-muted);
}
.btn.secondary:disabled{ opacity:.45; cursor:not-allowed; }

.spinner{
  width:16px; height:16px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.35);
  border-top-color: rgba(255,255,255,.95);
  animation: spin .9s linear infinite;
  display:none;
}
.btn.loading .spinner{ display:inline-block; }
@keyframes spin{ to{ transform:rotate(360deg);} }

/* =========================================================
   Account button + menu
   ========================================================= */
.acctBtn{
  border:1px solid var(--line);
  background: var(--surface-1);
  color: var(--text);
  border-radius: 999px;
  padding: 8px 10px;
  cursor: pointer;
  display:inline-flex;
  align-items:center;
  gap:10px;
  box-shadow:none;
}
.acctBtn:hover{ background: rgba(255,255,255,.06); }
.acctBtn:focus-visible{ outline: var(--focus-ring); outline-offset:2px; }

.acctAvatar{
  width:34px; height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  font-weight: 850;
  letter-spacing: .2px;
}
.acctAvatar--icon{ font-size: 18px; line-height: 1; }
.acctAvatar--initial{ background: var(--btn); border-color: var(--btn); color: #fff; font-size: 14px; }
.acctAvatar img{ width:100%; height:100%; object-fit:cover; display:block; }

.acctBurger{
  width:18px; height:14px;
  display:inline-block;
  position:relative;
  opacity:.9;
}
.acctBurger::before{
  content:"";
  position:absolute;
  left:0; right:0; top:2px;
  height:2px;
  background: rgba(234,240,255,.75);
  border-radius:999px;
  box-shadow: 0 5px 0 rgba(234,240,255,.75), 0 10px 0 rgba(234,240,255,.75);
}

.menu{
  position:absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width:180px;
  border:1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--menu-bg);
  box-shadow: var(--shadow);
  overflow:hidden;
  z-index: 60;
}
.menu-item, a.menu-item, button.menu-item{
  display:flex;
  width:100%;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  padding:12px;
  font-size:13.5px;
  font-weight:700;
  color: var(--text);
  text-decoration:none;
  background:transparent;
  border:0;
  cursor:pointer;
  outline: none;
}
a.menu-item:visited{ color: var(--text); }
.menu-item:hover{ background: rgba(255,255,255,.06); }
.menu-item:focus-visible{ outline: var(--focus-ring); outline-offset:-2px; }
.menu-sep{ height:1px; background: rgba(255,255,255,.10); margin: 6px 0; }
.authed-only.hidden,
.unauthed-only.hidden{ display:none !important; }

/* =========================================================
   Modal / sign-in
   ========================================================= */
.modal-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 220;
}
.modal-overlay.hidden{ display:none !important; }

#modalRoot{
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  z-index: 300;
}
#modalRoot.hidden{ display:none !important; }

.signin-modal{
  width: min(520px, 100%);
  position: relative;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.5);
  box-shadow: var(--shadow), 0 0 0 1px rgba(0,0,0,.05);
  padding: 22px 22px 18px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transform: translateY(-48px);
}

.signin-x{
  position: absolute;
  top: 12px; right: 12px;
  width: 36px; height: 36px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  background: rgba(0,0,0,.08);
  color: rgba(0,0,0,.5);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}
.signin-x:hover{
  background: rgba(0,0,0,.12);
  border-color: rgba(0,0,0,.08);
  color: rgba(0,0,0,.7);
}

.signin-title{ margin: 6px 0 14px; text-align: center; font-size: 22px; font-weight: 850; letter-spacing: .2px; color: rgba(0,0,0,.85); }
.signin-brand{ color: var(--btn); }
.signin-subtitle{ margin: 0 0 16px; text-align: center; color: rgba(0,0,0,.55); font-size: 14px; line-height: 1.4; }
.signin-input{
  width: 100%;
  padding: 14px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(0,0,0,.15);
  background: rgba(255,255,255,.7);
  color: rgba(0,0,0,.85);
  font-size: 16px;
  outline: none;
}
.signin-input::placeholder{ color: rgba(0,0,0,.4); }
.signin-primary{ width: 100%; margin-top: 12px; min-width: auto; }
.signin-err{ margin-top: 12px; font-size: 13px; color: var(--err); display: none; text-align: center; }
.signin-err.show{ display:block; }

/* =========================================================
   Footer buildbar
   ========================================================= */
.buildbar{
  position: static;
  z-index: 50;
  max-width: 900px;
  margin: 24px auto 0;
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
  font-size: 11px;
  color: rgba(234,240,255,.45);
  padding: 10px 12px;
  background: rgba(11,16,32,.35);
  backdrop-filter: blur(6px);
  border-radius: var(--radius);
}
.buildbar span{ font-family: var(--mono); }
.buildbar a{ color: rgba(234,240,255,.72); text-decoration: underline; text-decoration-color: rgba(234,240,255,.35); }
.buildbar a:hover{ color: rgba(234,240,255,.9); text-decoration-color: rgba(234,240,255,.65); }
.buildbar > *{ display:inline-flex; align-items:center; }
.buildbar > * + *::before{ content:"\2022"; opacity:.6; margin: 0 10px; }

.dev-only{ display:none; }
.prod-only{ display:none; }
body.env-dev .dev-only{ display: initial; }
body.env-prod .prod-only{ display: initial; }

/* =========================================================
   Accessibility
   ========================================================= */
.sr-only{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}

/* =========================================================
   Home page - Hero layout
   ========================================================= */
.home-hero{
  position: relative;
  min-height: 100vh;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 24px 120px;
}
.home-hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0,0,0,.45) 0%,
    rgba(0,0,0,.25) 40%,
    rgba(0,0,0,.35) 100%
  );
  pointer-events: none;
}

.home-hero-inner{
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 960px;
  width: 100%;
  padding: 0 16px;
}

.home-brand{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
.home-brand svg{
  height: 32px;
  width: auto;
}

.home-heading{
  font-family: 'Inter', 'Open Sans', sans-serif;
  font-size: 36px;
  font-weight: 700;
  color: #fff;
  text-align: center;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
  margin: 0 0 32px;
  letter-spacing: -.2px;
}

.home-info{
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: min(600px, calc(100% - 48px));
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.5);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 14px 18px;
  text-align: center;
  color: var(--lt-text);
}
.home-info .api-selector{ margin-top: 0; padding-top: 0; }
.home-info .api-selector + .api-selector{ margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--lt-line); }
.home-info h3{ color: var(--lt-text-muted); font-size: 14px; font-weight: 600; margin: 0 0 6px; }

/* Home page: full-viewport layout */
body.home-page{ padding: 0; }
body.home-page .wrap{ width: 100%; min-height: auto; }
body.home-page .app-topbar{
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 120;
  margin: 0;
  padding: 14px 24px;
}
body.home-page #appChrome .title,
body.home-page #appChrome .subtitle{
  display: none;
}
body.home-page .buildbar{
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  margin: 0;
  background: rgba(11,16,32,.5);
  backdrop-filter: blur(6px);
}

/* Widget container on home page */
#skymonde-search{
  width: 100%;
  max-width: 920px;
}

/* =========================================================
   Destiny - Search widget (inside card)
   ========================================================= */
.dest-card{
  position: relative;
  text-align: left;
  gap: 8px;
}
.dest-card h2,
.dest-card h3{
  font-weight: 600;
  color: var(--lt-text-heading);
  margin: 14px 0 8px;
  font-size: 18px;
}
.dest-card h3{
  font-size: 15px;
  color: var(--lt-text-muted);
}

#responseTimeDisplay{
  position:absolute;
  top:18px;
  right:18px;
  color: var(--lt-text-muted);
  font-size:12px;
}

.info-line{ color: var(--lt-text-muted); font-size: 12px; }

.input-container{ position: relative; margin-bottom: 12px; }
.destinationInput{
  background: #fff;
  padding: 12px;
  border: 1px solid var(--lt-line);
  border-radius: 8px;
  width: 100%;
  font-size: 16px;
  font-family: inherit;
  color: transparent;
  caret-color: var(--lt-text);
  box-shadow: 0 3px 6px rgba(0,0,0,.03);
  transition: border .2s, box-shadow .2s;
}
.destinationInput:focus{
  outline: none;
  border-color: var(--btn);
  box-shadow: 0 0 0 4px rgba(37,99,235,.15);
}
.input-text{
  position:absolute; inset: 0;
  padding:12px;
  font-size:16px;
  pointer-events:none;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
  z-index:1;
}
.normal-text{ color: var(--lt-text); }
.ghost-text{ color: var(--lt-text-muted); }

/* Dropdown */
.dropdown{
  position: absolute;
  left: 0; right: 0;
  top: calc(100% + 4px);
  background: #fff;
  border: 1px solid var(--lt-line);
  border-radius: 8px;
  box-shadow: 0 6px 18px rgba(0,0,0,.12);
  display:none;
  z-index: 1000;
  max-height: 280px;
  overflow: auto;
}
.dropdown-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding:10px;
  cursor:pointer;
  font-size:13px;
  color: var(--lt-text);
}
.dropdown-item + .dropdown-item{ border-top: 1px solid var(--lt-line); }
.dropdown-item.child{ padding-left: 50px; }
.dropdown-item:hover{ background: var(--lt-bg-subtle); }
.content{ display:flex; align-items:center; gap:10px; min-width:0; flex:1; }
.icon-container{
  width:32px; height:32px;
  border-radius:4px;
  overflow:hidden;
  background-size:contain;
  background-repeat:no-repeat;
  flex: 0 0 32px;
}
.text-container{ min-width:0; flex:1; }
.text-container > div:first-child{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dest-subtitle{ color: var(--lt-text-muted); font-size:12px; }
.expand-toggle{ width: 20px; text-align:center; user-select:none; }
.highlight-text{ font-weight: 800; text-decoration: underline; color: #400; }

.api-selector{ margin-top:12px; padding-top:10px; text-align:center; }
.api-selector a{ font-size:14px; color: var(--lt-link); text-decoration:none; margin: 0 10px; }
.api-selector a:hover{ text-decoration: underline; color: var(--lt-link-hover); }
.test-params, .locale-selector{ margin-top:10px; padding-top:10px; border-top:1px solid var(--lt-line); text-align:center; }
.test-params input[type="text"],
.locale-selector select{
  width:80%;
  padding:8px;
  border:1px solid var(--lt-line);
  border-radius:8px;
  font-size:14px;
  background: #fff;
  color: var(--lt-text);
}
.test-params input::placeholder{ color: var(--lt-text-muted); }

#map-it-button{
  padding: 12px 20px;
  border:1px solid var(--lt-line);
  border-radius:8px;
  background: #fff;
  color: var(--lt-text);
  font-size:16px;
  cursor:pointer;
  transition: background-color .2s, box-shadow .2s;
}
#map-it-button:hover{
  background: var(--lt-bg-subtle);
  box-shadow: 0 0 0 4px rgba(37,99,235,.15);
}

/* Icons (fallbacks) */
.icon-airport {
  background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgZmlsbD0ibm9uZSIgdmlld0JveD0iMCAwIDI0IDI0Ij48cGF0aCBmaWxsPSIjNTU1RjZEIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0yIDE5LjI1YS43NS43NSAwIDAgMCAwIDEuNWgxNmEuNzUuNzUgMCAxIDAgMC0xLjV6TTIyLjQyNyA2LjE4M2MtMi4wNDItMi43ODYtNS44MjUtMy43MS04LjkyNy0yLjI0LTEuMjY0LjYtMi41MjUgMS4yMTItMy43ODQgMS44MjNsLTEuNjg1LjgxNi0uMDIyLjAxMS0uMTYxLjA3OGMtLjU1OS4yNy0uNzM2LjI3Ny0uODE1LjI2Mi0uMjYxLS4wNDgtLjQ3Mi0uMzQ0LS42NDMtLjUzNC0uMjA4LS4yMzItLjM4OS0uNDg2LS42MDEtLjcxMy0uMjQyLS4yNi0uNjE4LS42MDMtMS4xMzMtLjcwOWExLjcgMS43IDAgMCAwLS42Ny4wMDVjLS4yMzQuMDQxLS41MTUuMTI2LS44MDEuMTk2YTYgNiAwIDAgMC0uNzYyLjIyM2MtLjM1NS4xNDItLjgwOC40MDQtMS4wNDQuOTM1LS4xNS4zMzctLjE0Ni42Ny0uMTAzLjk2Ny4wMzkuMjcyLjEyNC41OTEuMjE2LjkzNmwuMDEuMDM3LjI4NyAxLjA3Ny4wMTMuMDVjLjIyNS44NDMuNDEzIDEuNTUuNjQgMi4wOS4yNC41NzMuNTYzIDEuMDY0IDEuMTE4IDEuMzc3LjU1NC4zMTMgMS4xNDMuMzQgMS43NjQuMjU4LjU4OC0uMDc4IDEuMzA1LS4yNzEgMi4xNjUtLjUwM2wuMDUtLjAxNCAyLjE2NS0uNTgzLS4yNjMgMS4yMzNjLS4xOTguOTI1LjY2MSAxLjY4MSAxLjUzNyAxLjQ0NWwyLjI2Mi0uNjA5YTIuNzYgMi43NiAwIDAgMCAxLjY4LTEuMzAxbDEuMjI4LTIuNDI4YS4yMi4yMiAwIDAgMSAuMTM4LS4xMTRsNS4xNTktMS4zOWguMDAxYzEuMDg4LS4yOTUgMS43MzUtMS42MzQuOTg0LTIuNjc2em0tMTIuMDQ3LjkyOC44My0uNDAzLjAxOC0uMDA4cTEuNDU0LS43MDYgMi45MTUtMS40MDFjMi40Ni0xLjE2NiA1LjQ2MS0uNDI4IDcuMDcyIDEuNzY4YS4xOC4xOCAwIDAgMSAuMDE4LjE4Ni4yOC4yOCAwIDAgMS0uMTguMTY0bC01LjE1NyAxLjM5YTEuNzIgMS43MiAwIDAgMC0xLjA4Ny44ODRsLTEuMjE1IDIuNDA0Yy0uMTY1LjI3LS40MzIuNDctLjc0NS41NTRsLTEuODUuNDk4LjM2MS0xLjY5NGEuOTQ0Ljk0NCAwIDAgMC0xLjE2OC0xLjExbC0zLjA0NC44MmMtLjkyMi4yNDktMS41NDMuNDE0LTIuMDIyLjQ3OC0uNDU5LjA2LS42NzQuMDEtLjgyOC0uMDc3LS4xNTItLjA4NS0uMy0uMjM3LS40NzMtLjY1LS4xODItLjQzNS0uMzQ1LTEuMDQtLjU4Ny0xLjk0N0wyLjk1MSA3Ljg5Yy0uMTA1LS4zOTQtLjE2Ni0uNjI3LS4xOS0uOGEuNi42IDAgMCAxLS4wMS0uMTQ5Yy4wMS0uMDIuMDQ4LS4wNzUuMjI3LS4xNDYuMjQyLS4wOTYuNTAzLS4xNC43NTQtLjIwOC4yMjQtLjA2LjQzNi0uMTMyLjY2OC0uMTIzLjA1Ni4wMjcuMTUuMDk0LjI5My4yNDUuMDg4LjA5NS4xNzUuMjAxLjI3My4zMjNsLjAzMy4wNGMuMDg0LjEwNS4xOC4yMjQuMjc1LjMzLjQyLjQ2Ni44NzQuODkzIDEuNDg2IDEuMDA2LjYwNi4xMTMgMS4xODQtLjExOCAxLjc0LS4zODZ6IiBjbGlwLXJ1bGU9ImV2ZW5vZGQiPjwvcGF0aD48L3N2Zz4=');
}
.icon-city {
  background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMiIgaGVpZ2h0PSIyMiIgZmlsbD0ibm9uZSIgdmlld0JveD0iMCAwIDIyIDIyIj48cGF0aCBmaWxsPSIjNTU1RjZEIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik04LjExNCAzLjM0MWMtLjA2My4yOTEtLjA5My42ODgtLjA5MyAxLjI0MlYxOS40OGgzLjIwOHYtNC4yOThjLS4wMDEtLjcxMi0uMDAyLTEuMjk0LjI2Mi0xLjgxLjE0Ni0uMjg1LjM0Ni0uNTA2LjU4LS43MTMuMjItLjE5NC41LS40MDMuODI5LS42NDdsLjUxMi0uMzgxYy41MTQtLjM4Mi45NDctLjcwMyAxLjMzLS45MjUuMzQyLS4xOTYuNjg3LS4zMzkgMS4wNy0uMzhWNC41ODNjMC0uNTU0LS4wMy0uOTUtLjA5My0xLjI0Mi0uMDYyLS4yODMtLjE0Ny0uNDItLjIyNy0uNXMtLjIxNy0uMTY0LS41LS4yMjdjLS4yOTEtLjA2My0uNjg4LS4wOTMtMS4yNDItLjA5M2gtMy42NjdjLS41NTQgMC0uOTUuMDMtMS4yNDIuMDkzLS4yODMuMDYzLS40Mi4xNDctLjUuMjI3cy0uMTY0LjIxNy0uMjI3LjVtOS4wNzMgNy4yOFY0LjU4M2MwLS41ODMtLjAzLTEuMDk5LS4xMjUtMS41MzctLjA5OC0uNDQ2LS4yNzQtLjg1NC0uNTk4LTEuMTc3cy0uNzMxLS41LTEuMTc3LS41OTdjLS40MzgtLjA5Ny0uOTUzLS4xMjYtMS41MzctLjEyNmgtMy42NjdjLS41ODMgMC0xLjA5OS4wMy0xLjUzNy4xMjYtLjQ0Ni4wOTctLjg1NC4yNzQtMS4xNzcuNTk3cy0uNS43MzEtLjU5NyAxLjE3N2MtLjA5Ny40MzgtLjEyNi45NTQtLjEyNiAxLjUzN1YxOS40OGgtMi43NXYtNC4yNjZjLjMzNy0uMTQ0LjYyLS4zODYuODM1LS42Ny4zNDYtLjQ2My41NC0xLjA3LjU0LTEuNzFzLS4xOTQtMS4yNDctLjU0LTEuNzA5LS44NzgtLjgxMi0xLjUyMy0uODEyLTEuMTc2LjM1LTEuNTIyLjgxMi0uNTQgMS4wNjktLjU0IDEuNzFjMCAuNjQuMTk0IDEuMjQ2LjU0IDEuNzA4LjIxNC4yODUuNDk3LjUyNy44MzUuNjcxdjQuMjY2aC0uNjg4YS42ODguNjg4IDAgMCAwIDAgMS4zNzVoMTYuNXEuMTcyLS4wMDEuMzE1LS4wNzZjLjU1LS4wNzYgMS4wNS0uMjM5IDEuNDU3LS42MjcuNDIyLS40MDQuNTk3LS45MS42NzUtMS40Ny4wNzQtLjUyNS4wNzQtMS4xODUuMDc0LTEuOTY5di0xLjUzYy4wMDEtLjcxMy4wMDItMS4yOTUtLjI2Mi0xLjgxYTIuNCAyLjQgMCAwIDAtLjU4LS43MTRjLS4yMi0uMTk0LS41LS40MDMtLjgyOS0uNjQ3bC0uNTEyLS4zODFjLS41MTQtLjM4Mi0uOTQ2LS43MDMtMS4zMy0uOTI1em0tLjQ1OCA4Ljg1OGMuNzU5IDAgMS4yOS0uMDA2IDEuNjk1LS4wNTguNDI4LS4wNTUuNjEyLS4xNTEuNzMtLjI2NC4xMTUtLjExLjIxLS4yNzMuMjY1LS42NjguMDU4LS40MTguMDYtLjk4LjA2LTEuODI2di0xLjM1MmMwLS45MS0uMDE3LTEuMTMtLjExLTEuMzEzLS4wNDEtLjA3OS0uMTA4LS4xNjktLjI2OS0uMzEtLjE3LS4xNTEtLjQwMi0uMzI1LS43NTktLjU5bC0uNDU4LS4zNGMtLjU1NC0uNDEyLS45MjItLjY4NS0xLjIyOS0uODYtLjI5LS4xNjgtLjQ2MS0uMjEtLjYxMi0uMjFzLS4zMjQuMDQyLS42MTMuMjFjLS4zMDYuMTc1LS42NzUuNDQ4LTEuMjI5Ljg2bC0uNDU4LjM0Yy0uMzU3LjI2NS0uNTkuNDM5LS43Ni41OS0uMTYuMTQxLS4yMjcuMjMxLS4yNjcuMzEtLjA5My4xODMtLjExLjQwMi0uMTEgMS4zMTN2NC4xNjhoMi43NXYtMS4xNDZhLjY4Ny42ODcgMCAxIDEgMS4zNzQgMHptLTYuNDE3LTEzLjk4YzAtLjM3OS4zMDgtLjY4Ny42ODgtLjY4N2gxLjgzM2EuNjg4LjY4OCAwIDAgMSAwIDEuMzc1SDExYS42OS42OSAwIDAgMS0uNjg4LS42ODdtMCAyLjc1YzAtLjM3OS4zMDgtLjY4Ny42ODgtLjY4N2gxLjgzM2EuNjg4LjY4OCAwIDAgMSAwIDEuMzc1SDExYS42OS42OSAwIDAgMS0uNjg4LS42ODdtLTcuNTI2IDMuN2MtLjE1MS4yMDItLjI2NS41MTItLjI2NS44ODRzLjExNC42ODIuMjY1Ljg4NC4zMDcuMjYyLjQyMi4yNjIuMjcxLS4wNi40MjMtLjI2MmMuMTUtLjIwMi4yNjUtLjUxMi4yNjUtLjg4NHMtLjExNC0uNjgyLS4yNjUtLjg4NC0uMzA4LS4yNjItLjQyMy0uMjYyLS4yNy4wNi0uNDIyLjI2MiIgY2xpcC1ydWxlPSJldmVub2RkIj48L3BhdGg+PC9zdmc+');
}
.icon-map-pin {
  background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNSIgaGVpZ2h0PSIyNCIgZmlsbD0ibm9uZSIgdmlld0JveD0iMCAwIDI1IDI0Ij48cGF0aCBmaWxsPSIjNTU1RjZEIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMi41IDcuMjVhMS43NSAxLjc1IDAgMSAwIDAgMy41IDEuNzUgMS43NSAwIDAgMCAwLTMuNU05LjI1IDlhMy4yNSAzLjI1IDAgMSAxIDYuNSAwIDMuMjUgMy4yNSAwIDAgMS02LjUgMCIgY2xpcC1ydWxlPSJldmVub2RkIj48L3BhdGg+PHBhdGggZmlsbD0iIzU1NUY2RCIgZmlsbC1ydWxlPSJldmVub2RkIiBkPSJNMTIuNSAxLjI1Yy0zLjA1IDAtNS45NDggMS44NTUtNy4xNTkgNC43NjYtMS4xMjcgMi43MS0uNTE0IDUuMDE5Ljc1MSA2Ljk4NiAxLjAzMyAxLjYwNiAyLjU0IDMuMDQgMy44ODUgNC4zMThxLjM4NC4zNjQuNzQ0LjcxMmwuMDAyLjAwMmEyLjU2MyAyLjU2MyAwIDAgMCAzLjU1NSAwcS4zNC0uMzI3LjcwMS0uNjY5aC4wMDFjMS4zNTktMS4yODggMi44ODctMi43MzYgMy45My00LjM2MiAxLjI2NC0xLjk2OSAxLjg3NS00LjI4Ljc1LTYuOTg3QzE4LjQ0OCAzLjEwNSAxNS41NSAxLjI1IDEyLjUgMS4yNU02LjcyNiA2LjU5MkM3LjcgNC4yNTQgMTAuMDQxIDIuNzUgMTIuNSAyLjc1czQuODAyIDEuNTA0IDUuNzc0IDMuODQyYy44OSAyLjE0LjQ0NCAzLjkzMy0uNjI2IDUuNjAxLS45MzYgMS40NTgtMi4zMDcgMi43Ni0zLjY3IDQuMDU0cS0uMzc0LjM1My0uNzQuNzA2YTEuMDYzIDEuMDYzIDAgMCAxLTEuNDc0LjAwMXEtLjM5MS0uMzc5LS43OS0uNzU2Yy0xLjM0NS0xLjI4Mi0yLjY5NC0yLjU2OC0zLjYyLTQuMDA3LTEuMDcyLTEuNjY2LTEuNTItMy40NTUtLjYyOC01LjZNNy4yNSAxOS45ODhhLjc1Ljc1IDAgMCAwLTEuNS4wMTJjMCAuNjA0LjM2OCAxLjA2Ljc1NyAxLjM2Ny4zOTguMzE0LjkyNy41NjMgMS41MTMuNzU5IDEuMTgxLjM5MyAyLjc2NS42MjQgNC40OC42MjRzMy4yOTktLjIzIDQuNDgtLjYyNGMuNTg2LS4xOTYgMS4xMTUtLjQ0NSAxLjUxMy0uNzU5LjM4OS0uMzA2Ljc1Ny0uNzYzLjc1Ny0xLjM2N2EuNzUuNzUgMCAwIDAtMS41LS4wMTJjLS4wMDcuMDItLjA0Mi4wODgtLjE4Ni4yMDEtLjIxLjE2Ni0uNTYuMzQ3LTEuMDU4LjUxNC0uOTkxLjMzLTIuNDA3LjU0Ny00LjAwNi41NDdzLTMuMDE1LS4yMTctNC4wMDUtLjU0N2MtLjUtLjE2Ny0uODUtLjM0OC0xLjA2LS41MTQtLjE0My0uMTEzLS4xNzgtLjE4Mi0uMTg1LS4yIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiPjwvcGF0aD48L3N2Zz4=');
}
.icon-hotel {
  background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgZmlsbD0ibm9uZSIgdmlld0JveD0iMCAwIDIwIDIwIj48cGF0aCBmaWxsPSIjNTU1QjZEIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMCAyLjEyOGEzLjYgMy42IDAgMCAwLTIuMTgzLjczMyAzLjYxIDMuNjEgMCAwIDAtMS40MzQgMi44ODQuNjQuNjQgMCAwIDEtLjYzOC42MzhIMi45Nzl2OC43MjNjMCAuODIuMDAxIDEuMzcyLjA1NiAxLjc4My4wNTMuMzkzLjE0NC41Ni4yNTUuNjcyLjExMS4xMS4yOC4yMDIuNjcyLjI1NS40MTEuMDU1Ljk2Mi4wNTYgMS43ODMuMDU2SDcuNjZ2LTIuNzY2YTIuMzQgMi4zNCAwIDEgMSA0LjY4IDB2Mi43NjZoMS45MTVjLjgyIDAgMS4zNzItLjAwMSAxLjc4My0uMDU2LjM5My0uMDUzLjU2LS4xNDQuNjcyLS4yNTUuMTEtLjExMS4yMDItLjI4LjI1NS0uNjcyLjA1NS0uNDExLjA1Ni0uOTYyLjA1Ni0xLjc4M1Y2LjM4M2gtMi43NjZhLjY0LjY0IDAgMCAxLS42MzgtLjYzOCAzLjYxIDMuNjEgMCAwIDAtMS40Ni0yLjkwNEEzLjYgMy42IDAgMCAwIDEwIDIuMTI4TTEwIC44NWE0Ljg3IDQuODcgMCAwIDAtMi43NTkuODUxSDMuNTkzYy0uMzc2IDAtLjgyNi4xMDItMS4xOTMuNDY1QzEuNjI1IDIuOTM1IDEuMjMgNC4xNS44NyA1LjU5YS42MzguNjM4IDAgMCAwIC42Mi43OTNoLjIxMnY4Ljc2OGMwIC43NjQgMCAxLjQwMi4wNjggMS45MDguMDcyLjUzNC4yMyAxLjAxNy42MTggMS40MDQuMzg3LjM4OC44Ny41NDYgMS40MDQuNjE4LjUwNi4wNjggMS4xNDQuMDY4IDEuOTA4LjA2OGg4LjZjLjc2NCAwIDEuNDAyIDAgMS45MDgtLjA2OC41MzQtLjA3MiAxLjAxNy0uMjMgMS40MDQtLjYxOC4zODgtLjM4Ny41NDYtLjg3LjYxOC0xLjQwNC4wNjgtLjUwNi4wNjgtMS4xNDQuMDY4LTEuOTA4VjYuMzgzaC4yMTNhLjYzOC42MzggMCAwIDAgLjYxOS0uNzkzYy0uMzYtMS40NC0uNzU1LTIuNjU1LTEuNTMtMy40MjMtLjM2Ny0uMzYzLS44MTctLjQ2NS0xLjE5My0uNDY1aC0zLjY0OEE0Ljg3IDQuODcgMCAwIDAgMTAgLjg1Mk0zLjU5MyAyLjk4aDIuMzdhNC45IDQuOSAwIDAgMC0uODE1IDIuMTI3SDIuMzJjLjI5Mi0xLjAwNC41ODUtMS42NDMuOTc4LTIuMDMyLjA1Ny0uMDU3LjE0Mi0uMDk1LjI5NC0uMDk1TTE3LjY4IDUuMTA2aC0yLjgyN2E0LjkgNC45IDAgMCAwLS44MTUtMi4xMjdoMi4zN2MuMTUyIDAgLjIzNy4wMzguMjk0LjA5NS4zOTMuMzkuNjg2IDEuMDI4Ljk3OCAyLjAzMm0tNi42MTUgMTIuNzY2di0yLjc2NmExLjA2NCAxLjA2NCAwIDEgMC0yLjEyOCAwdjIuNzY2em0tNi4xNy05LjM2MWEuNjM4LjYzOCAwIDAgMCAwIDEuMjc2aC40MjVhLjYzOC42MzggMCAxIDAgMC0xLjI3NnptMCAyLjk3OGEuNjM4LjYzOCAwIDAgMCAwIDEuMjc3aC40MjVhLjYzOC42MzggMCAxIDAgMC0xLjI3N3ptOS4xNDktMi4zNGMwLS4zNTMuMjg1LS42MzguNjM4LS42MzhoLjQyNWEuNjM4LjYzOCAwIDAgMSAwIDEuMjc2aC0uNDI1YS42NC42NCAwIDAgMS0uNjM4LS42MzhtMCAyLjk3OWMwLS4zNTMuMjg1LS42MzkuNjM4LS42MzloLjQyNWEuNjM4LjYzOCAwIDAgMSAwIDEuMjc3aC0uNDI1YS42NC42NCAwIDAgMS0uNjM4LS42MzhNOS4zNjIgNi41OTZhLjYzOC42MzggMCAxIDAtMS4yNzcgMHYyLjU1M2EuNjM4LjYzOCAwIDEgMCAxLjI3NyAwVjguNTFoMS4yNzZ2LjYzOGEuNjM4LjYzOCAwIDAgMCAxLjI3NyAwVjYuNTk2YS42MzguNjM4IDAgMCAwLTEuMjc3IDB2LjYzOEg5LjM2MnoiIGNsaXAtcnVsZT0iZXZlbm9kZCI+PC9wYXRoPjwvc3ZnPg==');
}

/* =========================================================
   Documentation page (light theme inside card)
   ========================================================= */
.docs-page .card-inner{
  max-width: 100%;
  background: var(--lt-bg);
  color: var(--lt-text);
  border-radius: var(--radius-sm);
  padding: 32px;
}

.docs-content{
  line-height: 1.7;
  font-size: 15px;
  color: var(--lt-text);
}

.docs-loading,
.docs-error{
  text-align: center;
  padding: 48px 24px;
  color: var(--lt-text-muted);
}

.docs-error h2{
  color: var(--err);
  margin-bottom: 12px;
}

/* Headings */
.docs-content h1,
.docs-content h2{
  font-weight: 700;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--lt-line);
  color: var(--lt-text-heading);
}

.docs-content h1{
  font-size: 28px;
  margin: 0 0 16px 0;
}

.docs-content h2{
  font-size: 22px;
  font-weight: 600;
  margin: 32px 0 16px 0;
}

.docs-content h3,
.docs-content h4,
.docs-content h5,
.docs-content h6{
  font-weight: 600;
  color: var(--lt-text);
}

.docs-content h3{
  font-size: 18px;
  margin: 24px 0 12px 0;
}

.docs-content h4,
.docs-content h5,
.docs-content h6{
  font-size: 16px;
  margin: 20px 0 10px 0;
}

/* Paragraphs */
.docs-content p{
  margin: 0 0 16px 0;
}

/* Links */
.docs-content a{
  color: var(--lt-link);
  text-decoration: underline;
  text-decoration-color: rgba(59, 130, 246, 0.4);
  font-weight: 400;
}
.docs-content a:hover{
  color: var(--lt-link-hover);
  text-decoration-color: rgba(37, 99, 235, 0.7);
}

/* Lists */
.docs-content ul,
.docs-content ol{
  margin: 0 0 16px 0;
  padding-left: 24px;
}

.docs-content li{
  margin-bottom: 6px;
}

.docs-content li > ul,
.docs-content li > ol{
  margin-top: 6px;
  margin-bottom: 0;
}

/* Code */
.docs-content code{
  font-family: var(--mono);
  font-size: 13px;
  background: var(--lt-bg-code);
  color: var(--lt-text);
  padding: 2px 6px;
  border-radius: 4px;
}

.docs-content pre{
  background: var(--lt-bg-code);
  border-radius: var(--radius-sm);
  padding: 16px;
  margin: 0 0 16px 0;
  border: 1px solid var(--lt-line-dark);
  white-space: pre-wrap;
  word-wrap: break-word;
}

.docs-content pre code{
  background: none;
  padding: 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--lt-text);
  white-space: pre-wrap;
  word-wrap: break-word;
}

/* Tables */
.docs-content table{
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 16px 0;
  font-size: 14px;
}

.docs-content th,
.docs-content td{
  text-align: left;
  padding: 10px 12px;
  border: 1px solid var(--lt-line);
}

.docs-content th{
  background: var(--lt-line);
  font-weight: 600;
  color: var(--lt-text-heading);
}

.docs-content tr:nth-child(even){
  background: var(--lt-bg-subtle);
}

/* Blockquotes */
.docs-content blockquote{
  margin: 0 0 16px 0;
  padding: 12px 16px;
  border-left: 4px solid var(--lt-link-hover);
  background: var(--lt-bg-subtle);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  color: var(--lt-text);
}

.docs-content blockquote p:last-child{
  margin-bottom: 0;
}

/* Horizontal rule */
.docs-content hr{
  border: none;
  border-top: 1px solid var(--lt-line);
  margin: 32px 0;
}

/* Strong / emphasis */
.docs-content strong{
  font-weight: 600;
  color: var(--lt-text-heading);
}

/* First element no top margin */
.docs-content > *:first-child{
  margin-top: 0;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 720px){
  body{
    align-items:flex-start;
    justify-content:flex-start;
    padding:14px;
  }
  .wrap{ min-height: auto; }

  .app-topbar{
    position: sticky;
    top: 0;
    z-index: 140;
    margin: -14px -14px 12px;
    background: transparent;
    transform: translateZ(0);
    transition: transform 160ms ease-out, background 180ms ease-out, box-shadow 180ms ease-out;
  }
  .app-topbar .topbar-inner{ padding: 10px 14px; }
  .app-topbar.is-floating{
    background: rgba(16,26,51,.92);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 14px 30px rgba(0,0,0,.45);
  }
  .app-topbar.is-hidden{ transform: translateY(calc(-1 * (var(--topbar-h, 72px) + 14px))); }

  .buildbar{
    margin: 14px 0 0;
    max-width: none;
    border: 1px solid rgba(255,255,255,.10);
  }

  /* Docs mobile */
  .docs-page.card{
    margin-left: -14px;
    margin-right: -14px;
    border-radius: 0;
    width: calc(100% + 28px);
  }

  .docs-page .card-inner{
    padding: 20px;
    border-radius: 0;
  }

  .docs-content table{
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .docs-content th,
  .docs-content td{
    padding: 8px 10px;
    font-size: 13px;
  }

  .docs-content h1{ font-size: 24px; }
  .docs-content h2{ font-size: 20px; }
  .docs-content h3{ font-size: 17px; }

  /* Home hero mobile */
  .home-hero{ padding: 70px 14px 110px; }
  .home-heading{ font-size: 26px; margin-bottom: 24px; }
  .home-info{ width: min(600px, calc(100% - 28px)); bottom: 18px; }
  body.home-page .app-topbar{ padding: 10px 14px; }
}
