/* ============================================================
   Orbital Focus — components for the generated pages
   (support center, blog, destinations, homepage showcases),
   nav actions, App Store button, and RTL.
   Loads after site.css; reuses its design tokens.
   ============================================================ */

/* ---------- Nav actions ---------- */
.nav-actions{ display:flex; align-items:center; gap:12px; flex-shrink:0; }
.nav-links{ margin-left:auto; }
.btn.sm{ padding:8px 16px; font-size:.9rem; }
.brand img{ border-radius:8px; object-fit:cover; }

/* ---------- App Store button ---------- */
.appstore-btn{
  background:#000; color:#fff; gap:10px; padding:10px 18px;
  border:1px solid rgba(255,255,255,.14);
}
.appstore-btn:hover{ color:#fff; background:#111; box-shadow:0 0 18px rgba(0,0,0,.45); }
.appstore-btn.ghost{ background:transparent; border:1px solid var(--line); color:var(--text); }
.appstore-glyph{
  width:22px; height:22px; flex:none;
  background:no-repeat center/contain url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="white"><path d="M16.36 12.78c-.02-2.2 1.8-3.26 1.88-3.31-1.03-1.5-2.62-1.71-3.19-1.73-1.36-.14-2.65.8-3.34.8-.69 0-1.75-.78-2.88-.76-1.48.02-2.85.86-3.61 2.19-1.54 2.67-.39 6.62 1.1 8.78.73 1.06 1.6 2.25 2.73 2.21 1.1-.04 1.51-.71 2.84-.71 1.32 0 1.7.71 2.86.69 1.18-.02 1.93-1.08 2.65-2.14.84-1.23 1.18-2.42 1.2-2.48-.03-.01-2.29-.88-2.31-3.48zM14.2 6.3c.6-.73 1.01-1.75.9-2.76-.87.04-1.92.58-2.55 1.31-.56.64-1.05 1.67-.92 2.65.97.08 1.96-.49 2.57-1.2z"/></svg>');
}
.appstore-btn.ghost .appstore-glyph{
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%235eb0ff"><path d="M16.36 12.78c-.02-2.2 1.8-3.26 1.88-3.31-1.03-1.5-2.62-1.71-3.19-1.73-1.36-.14-2.65.8-3.34.8-.69 0-1.75-.78-2.88-.76-1.48.02-2.85.86-3.61 2.19-1.54 2.67-.39 6.62 1.1 8.78.73 1.06 1.6 2.25 2.73 2.21 1.1-.04 1.51-.71 2.84-.71 1.32 0 1.7.71 2.86.69 1.18-.02 1.93-1.08 2.65-2.14.84-1.23 1.18-2.42 1.2-2.48-.03-.01-2.29-.88-2.31-3.48zM14.2 6.3c.6-.73 1.01-1.75.9-2.76-.87.04-1.92.58-2.55 1.31-.56.64-1.05 1.67-.92 2.65.97.08 1.96-.49 2.57-1.2z"/></svg>');
}
.appstore-text{ display:flex; flex-direction:column; align-items:flex-start; line-height:1.05; }
.appstore-text small{ font-size:.62rem; font-weight:500; opacity:.85; }
.appstore-text strong{ font-size:1.05rem; font-weight:700; }
.cta-row.center{ justify-content:center; }

/* ---------- Feature showcases (screenshot + copy) ---------- */
.showcases{ display:flex; flex-direction:column; }
.showcase{ padding:clamp(48px,8vw,96px) 0; }
.showcase:nth-child(even){ background:rgba(17,26,48,.35); }
.showcase-inner{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,56px);
  align-items:center;
}
.showcase.reverse .showcase-inner{ direction:rtl; }
.showcase.reverse .showcase-copy,
.showcase.reverse .showcase-media{ direction:ltr; }
@media (max-width:820px){
  .showcase-inner{ grid-template-columns:1fr; }
  .showcase.reverse .showcase-inner{ direction:ltr; }
  .showcase-media{ order:-1; max-width:280px; margin:0 auto; }
}
.showcase-copy h2{
  font-size:clamp(1.5rem,3vw,2rem); line-height:1.15; margin:0 0 14px; letter-spacing:-.01em;
}
.showcase-copy p{ color:var(--dim); margin:0 0 12px; font-size:1.02rem; line-height:1.55; }
.showcase-copy p:last-child{ margin-bottom:0; }
.showcase-media{ display:flex; justify-content:center; }

/* Hangar showcase: copy on top, full-bleed marquee below */
.showcase.showcase-hangar .showcase-inner{
  display:block;
}
.showcase.showcase-hangar .showcase-copy{
  max-width:38rem;
  margin-bottom:clamp(28px,4vw,44px);
}
/* Break the marquee out of the centered .container to span the FULL viewport.
   left:50% + translateX(-50%) + width:100vw is the same full-bleed trick the
   hero globe uses; max-width:none is essential — max-width:100% would clamp it
   back to the (narrower) container and the band would stop partway. The page
   sets overflow-x:hidden globally, so 100vw never adds a horizontal scrollbar. */
.showcase.showcase-hangar .showcase-media{
  display:block;
  position:relative;
  left:50%;
  transform:translateX(-50%);
  width:100vw;
  max-width:none;
  overflow:hidden;
}
.showcase.showcase-hangar .rocket-marquee{
  display:block;
  width:100%;
  min-width:0;
  overflow:hidden;
}

/* ---------- Hangar rocket marquee ---------- */
.rocket-marquee{
  position:relative;
  padding:clamp(20px,3vw,28px) 0 clamp(20px,3vw,32px);
  background:
    radial-gradient(ellipse 90% 70% at 50% 100%, rgba(94,176,255,.14), transparent 65%),
    linear-gradient(180deg, rgba(17,26,48,.5) 0%, rgba(7,11,22,.2) 100%);
  border-block:1px solid rgba(94,176,255,.08);
}
.rocket-marquee-hint{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:8px 12px;
  margin:0 0 14px;
  padding:0 clamp(16px,4vw,24px);
  font-size:.88rem;
  font-weight:600;
  color:var(--dim);
  text-align:center;
  transition:opacity .3s ease;
}
.rocket-marquee.is-browsing .rocket-marquee-hint{
  opacity:.45;
}
.rocket-marquee-hint-pill{
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--accent);
  background:rgba(94,176,255,.1);
  border:1px solid rgba(94,176,255,.22);
  border-radius:999px;
  padding:4px 10px;
}
.rocket-marquee-hint-arrows{
  display:inline-block;
  color:var(--accent);
  animation:rocket-hint-nudge 2.2s ease-in-out infinite;
}
@keyframes rocket-hint-nudge{
  0%, 100%{ transform:translateX(0); opacity:.7; }
  50%{ transform:translateX(4px); opacity:1; }
}
.rocket-marquee-viewport{
  display:block;
  width:100%;
  max-width:100%;
  min-width:0;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  scroll-behavior:auto;
  touch-action:pan-x;
  cursor:grab;
  scrollbar-width:thin;
  scrollbar-color:rgba(94,176,255,.35) transparent;
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%);
  mask-image:linear-gradient(90deg, transparent 0%, #000 5%, #000 95%, transparent 100%);
}
.rocket-marquee-viewport::-webkit-scrollbar{ height:6px; }
.rocket-marquee-viewport::-webkit-scrollbar-thumb{
  background:rgba(94,176,255,.35);
  border-radius:999px;
}
.rocket-marquee.is-dragging .rocket-marquee-viewport{ cursor:grabbing; scroll-behavior:auto; }
.rocket-marquee-viewport:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:4px;
}
.rocket-marquee-track{
  display:flex;
  width:max-content;
}
.rocket-marquee-group{
  display:flex;
  align-items:flex-end;
  gap:clamp(28px,4vw,56px);
  padding:0 clamp(20px,3vw,36px);
}
.rocket-marquee-item{
  flex:0 0 auto;
  margin:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  width:clamp(100px,14vw,160px);
}
.rocket-marquee-sprite{
  position:relative;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  width:100%;
  min-height:clamp(140px,20vw,260px);
}
.rocket-marquee-pad{
  position:absolute;
  bottom:4px;
  left:50%;
  transform:translateX(-50%);
  width:clamp(72px,10vw,120px);
  height:12px;
  border-radius:50%;
  background:radial-gradient(ellipse, rgba(94,176,255,.4), transparent 72%);
  opacity:.65;
  pointer-events:none;
}
.rocket-marquee-item img{
  position:relative;
  z-index:1;
  height:clamp(140px,20vw,260px);
  width:auto;
  max-width:100%;
  object-fit:contain;
  image-rendering:pixelated;
  image-rendering:crisp-edges;
  filter:drop-shadow(0 16px 32px rgba(0,0,0,.55)) drop-shadow(0 0 24px rgba(94,176,255,.12));
  transition:transform .35s ease, filter .35s ease;
}
.rocket-marquee-item:hover .rocket-marquee-sprite img,
.rocket-marquee-item:focus-within .rocket-marquee-sprite img{
  transform:translateY(-6px) scale(1.04);
  filter:drop-shadow(0 22px 40px rgba(0,0,0,.6)) drop-shadow(0 0 32px rgba(94,176,255,.22));
}
.rocket-marquee-item figcaption{
  font-size:clamp(.72rem,1.6vw,.88rem);
  font-weight:600;
  color:var(--dim);
  text-align:center;
  letter-spacing:.03em;
  line-height:1.25;
  max-width:12ch;
}

/* "Many more" placeholder — an image-free frosted tile standing in for the
   unlockable fleet whose sprites we deliberately don't publish. */
.rocket-marquee-more{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:clamp(96px,12vw,140px);
  height:clamp(140px,20vw,260px);
  padding:14px 10px;
  border:1.5px dashed rgba(94,176,255,.32);
  border-radius:18px;
  background:linear-gradient(180deg, rgba(94,176,255,.08), rgba(94,176,255,.02));
  transition:border-color .35s ease, background .35s ease, transform .35s ease;
}
.rocket-marquee-item-more:hover .rocket-marquee-more,
.rocket-marquee-item-more:focus-within .rocket-marquee-more{
  border-color:rgba(94,176,255,.55);
  background:linear-gradient(180deg, rgba(94,176,255,.14), rgba(94,176,255,.04));
  transform:translateY(-6px);
}
.rocket-marquee-more-glyph{
  width:clamp(20px,3vw,28px);
  height:auto;
  fill:rgba(94,176,255,.55);
  filter:drop-shadow(0 0 12px rgba(94,176,255,.25));
}
.rocket-marquee-more-count{
  font-size:clamp(1.1rem,2.4vw,1.5rem);
  font-weight:800;
  letter-spacing:.02em;
  color:var(--accent);
  line-height:1;
}
.rocket-marquee-more-label{
  font-size:clamp(.62rem,1.3vw,.74rem);
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--dim);
  text-align:center;
  line-height:1.2;
}

/* Static / reduced-motion: scroll only, no auto-drift */
.rocket-marquee.is-static .rocket-marquee-hint-arrows{ animation:none; }

@media (prefers-reduced-motion: reduce){
  .rocket-marquee-hint-arrows{ animation:none; }
  .rocket-marquee-item img{ transition:none; }
}

/* ---------- iPhone device frame ---------- */
.device{ width:min(100%,280px); margin:0 auto; }
.device-bezel{
  position:relative; background:#0a0a0c; border-radius:44px; padding:10px;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.08),
    0 24px 60px rgba(0,0,0,.55),
    inset 0 0 0 1px rgba(255,255,255,.04);
}
.device-notch{
  position:absolute; top:10px; left:50%; transform:translateX(-50%);
  width:90px; height:26px; background:#0a0a0c; border-radius:0 0 18px 18px; z-index:2;
}
.device-screen{
  border-radius:36px; overflow:hidden; background:#000; line-height:0;
}
.device-screen img{
  display:block; width:100%; height:auto; aspect-ratio:390/844; object-fit:cover; object-position:top;
}
/* ---------- Doc page shell (support/blog/destinations/legal) ---------- */
.page-doc{ min-height:100vh; }
.support-hero{ padding:clamp(40px,6vw,72px) 0 clamp(20px,3vw,32px); text-align:center; }
.support-hero h1{ font-size:clamp(1.9rem,4vw,2.8rem); margin:0 0 12px; letter-spacing:-.01em; }
.support-hero .lede{ color:var(--dim); font-size:1.1rem; margin:0 auto 24px; max-width:48ch; }
.container.narrow{ max-width:760px; }

/* ---------- Support search ---------- */
.support-search{ position:relative; max-width:560px; margin:0 auto; }
.support-search input{
  width:100%; padding:14px 18px; font-size:1rem; font-family:inherit;
  color:var(--text); background:var(--panel); border:1px solid var(--line);
  border-radius:14px;
}
.support-search input:focus{ outline:none; border-color:var(--accent); box-shadow:var(--glow); }
.support-results{
  list-style:none; margin:8px 0 0; padding:6px; text-align:start;
  position:absolute; left:0; right:0; z-index:30;
  background:var(--panel); border:1px solid var(--line); border-radius:14px;
  box-shadow:0 18px 50px rgba(0,0,0,.35);
}
.support-results li a{
  display:flex; flex-direction:column; padding:10px 14px; border-radius:10px;
  color:var(--text);
}
.support-results li a:hover{ background:var(--panel2); text-decoration:none; }
.support-results .r-title{ font-weight:600; }
.support-results .r-coll{ font-size:.8rem; color:var(--dim); }
.support-noresults{ color:var(--dim); margin:10px 0 0; }

/* ---------- Collection grid ---------- */
.collection-grid{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:18px; margin:8px 0 40px;
}
.collection-card{ display:flex; gap:14px; padding:20px; align-items:flex-start; color:var(--text); }
.collection-card:hover{ text-decoration:none; box-shadow:var(--glow); transform:translateY(-2px); transition:.2s; }
.cc-icon{ font-size:1.7rem; flex:none; }
.cc-icon.big{ font-size:2.4rem; display:block; margin-bottom:8px; }
.cc-body{ display:flex; flex-direction:column; gap:4px; }
.cc-title{ font-weight:700; font-size:1.05rem; }
.cc-desc{ color:var(--dim); font-size:.92rem; }
.cc-count{ color:var(--accent); font-size:.8rem; font-weight:600; margin-top:4px; }

/* ---------- Breadcrumb ---------- */
.support-breadcrumb{ font-size:.85rem; color:var(--dim); margin:24px 0 18px; display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.support-breadcrumb a{ color:var(--dim); }
.support-breadcrumb a:hover{ color:var(--text); }
.support-breadcrumb .sep{ opacity:.5; }
.support-breadcrumb [aria-current="page"]{ color:var(--text); }

/* ---------- Collection / article lists ---------- */
.collection-head{ margin:8px 0 24px; }
.collection-head h1{ font-size:clamp(1.6rem,3vw,2.2rem); margin:0 0 8px; }
.collection-head .lede{ color:var(--dim); }
.article-list{ list-style:none; padding:0; margin:0 0 48px; display:flex; flex-direction:column; gap:10px; }
.article-list li a{
  display:flex; flex-direction:column; gap:3px; padding:16px 18px;
  border:1px solid var(--line); border-radius:14px; background:var(--panel);
  color:var(--text);
}
.article-list li a:hover{ border-color:var(--accent); text-decoration:none; }
.article-list .art-title{ font-weight:600; }
.article-list .art-desc{ color:var(--dim); font-size:.9rem; }

/* ---------- Article body ---------- */
.article.prose{ margin:0 0 32px; }
.article-meta{ color:var(--dim); font-size:.85rem; margin:0 0 24px; }
.article .callout{
  border:1px solid var(--line); border-inline-start:3px solid var(--accent);
  background:var(--panel2); border-radius:10px; padding:12px 16px; margin:18px 0;
}
.article .callout p{ margin:0; }
.article .callout-tip{ border-inline-start-color:var(--good); }
.article .callout-warning{ border-inline-start-color:var(--accent2); }
.steps-list{ counter-reset:step; list-style:none; padding:0; margin:18px 0; }
.steps-list .step-item{
  counter-increment:step; position:relative; padding-inline-start:42px; margin:0 0 16px;
}
.steps-list .step-item::before{
  content:counter(step); position:absolute; inset-inline-start:0; top:0;
  width:28px; height:28px; border-radius:50%; background:var(--accent);
  color:#04101f; font-weight:700; display:flex; align-items:center; justify-content:center;
  font-size:.85rem;
}
.steps-list .step-title{ display:block; font-weight:600; }
.steps-list .step-desc{ display:block; color:var(--dim); }

/* Feedback widget */
.article-feedback{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin:32px 0 0; padding-top:20px; border-top:1px solid var(--line); }
.article-feedback .fb-q{ color:var(--dim); font-weight:600; }
.fb-btn{
  border:1px solid var(--line); background:var(--panel2); color:var(--text);
  padding:6px 18px; border-radius:10px; cursor:pointer; font-family:inherit; font-weight:600;
}
.fb-btn:hover{ border-color:var(--accent); }
.fb-thanks{ color:var(--good); font-weight:600; }
.related{ margin:0 0 40px; }
.related h2{ font-size:1.1rem; margin:0 0 12px; }
.related ul{ margin:0; padding-inline-start:20px; }
.article-back{ margin:0 0 48px; }

/* ---------- Blog ---------- */
.post-list{ list-style:none; padding:0; margin:0 0 56px; display:grid; gap:18px; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); }
.post-card a{ display:block; padding:22px; color:var(--text); }
.post-card a:hover{ text-decoration:none; box-shadow:var(--glow); transform:translateY(-2px); transition:.2s; }
.post-card time{ color:var(--dim); font-size:.82rem; }
.post-card h2{ font-size:1.2rem; margin:8px 0 8px; }
.post-card p{ color:var(--dim); margin:0 0 12px; font-size:.95rem; }
.post-card .read-more{ color:var(--accent); font-weight:600; font-size:.9rem; }
.tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:24px; }
.tag{ font-size:.78rem; color:var(--dim); border:1px solid var(--line); border-radius:999px; padding:3px 12px; }

/* ---------- Destinations ---------- */
.dest-grid{ display:grid; gap:18px; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); margin:8px 0 56px; }
.dest-card{ display:flex; flex-direction:column; gap:6px; padding:22px; color:var(--text); }
.dest-card:hover{ text-decoration:none; box-shadow:var(--glow); transform:translateY(-2px); transition:.2s; }
.dest-emoji{ font-size:2rem; }
.dest-emoji.big{ font-size:3rem; display:block; margin-bottom:6px; }
.dest-name{ font-weight:700; font-size:1.15rem; }
.dest-stat{ color:var(--dim); font-size:.9rem; }
.dest-stat strong{ color:var(--text); }
.dest-lore{ color:var(--dim); font-size:.92rem; margin-top:4px; }
.pill{ display:inline-block; font-size:.65rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--accent2); border:1px solid var(--accent2); border-radius:999px; padding:2px 8px; vertical-align:middle; }
.dest-detail .lede{ color:var(--dim); font-size:1.1rem; }
.dest-stats{ display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:14px; margin:24px 0; }
.dest-stats .stat{ background:var(--panel2); border:1px solid var(--line); border-radius:12px; padding:14px; text-align:center; }
.dest-stats .stat-val{ display:block; font-size:1.2rem; font-weight:700; }
.dest-stats .stat-label{ display:block; color:var(--dim); font-size:.8rem; margin-top:4px; }

/* ---------- Support footer / misc ---------- */
.support-foot{ text-align:center; padding:32px; margin:0 0 56px; }
.support-foot h2{ margin:0 0 16px; font-size:1.3rem; }
.notfound{ text-align:center; padding:clamp(60px,12vw,140px) 0; }

/* ---------- RTL ---------- */
[dir="rtl"] .nav-links{ margin-left:0; margin-right:auto; }
[dir="rtl"] .appstore-text{ align-items:flex-end; }
[dir="rtl"] .back-link, [dir="rtl"] .article-back a{ direction:rtl; }
