/* ============================================================
   WEED SAMURAI -- Components (nav, buttons, cards, frames, footer)
   ============================================================ */

/* ---------- NAV ---------- */
.ws-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-h);
  z-index: 50;
  display: flex;
  align-items: center;
  transition: background var(--t-med) var(--ease-out), border-color var(--t-med);
  border-bottom: 1px solid transparent;
}
.ws-nav.is-scrolled {
  background: rgba(8, 10, 14, 0.78);
  backdrop-filter: blur(16px) saturate(140%);
  border-bottom: 1px solid var(--ink-500);
}
.ws-nav__inner {
  width: 100%; max-width: var(--container-wide);
  margin-inline: auto; padding-inline: var(--gutter);
  display: flex; align-items: center; justify-content: space-between;
}
.ws-brand {
  display: inline-flex; align-items: center; gap: 0.65rem;
  font-family: var(--font-display); font-weight: 600; font-size: 1.05rem;
  color: var(--mist); letter-spacing: 0.02em;
}
.ws-brand__mark { width: 34px; height: 34px; filter: drop-shadow(var(--glow-jade-soft)); }
.ws-brand__mark--small { width: 26px; height: 26px; }
.ws-brand b { color: var(--jade-500); font-weight: 600; }

.ws-nav__links { display: flex; align-items: center; gap: 0.2rem; }
.ws-nav__link {
  font-size: var(--fs-small); color: var(--steel-200);
  padding: 0.5rem 0.8rem; border-radius: var(--r-sm);
  transition: color var(--t-fast), background var(--t-fast);
  position: relative; white-space: nowrap;
}
.ws-nav__link:hover { color: var(--mist); background: var(--ink-600); }
.ws-nav__link.is-active { color: var(--jade-500); }

/* dropdown for "Apps" mega-menu */
.ws-nav__group { position: relative; }
.ws-nav__panel {
  position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%) translateY(8px);
  background: var(--ink-700); border: var(--border-hair); border-radius: var(--r-md);
  padding: 0.6rem; width: 540px; box-shadow: var(--shadow-lift);
  display: grid; grid-template-columns: 1fr 1fr; gap: 0.25rem;
  opacity: 0; visibility: hidden; transition: all var(--t-fast) var(--ease-out); z-index: 60;
}
.ws-nav__group:hover .ws-nav__panel,
.ws-nav__group:focus-within .ws-nav__panel { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.ws-nav__panel-item { display: flex; gap: 0.7rem; padding: 0.6rem 0.7rem; border-radius: var(--r-sm); transition: background var(--t-fast); }
.ws-nav__panel-item:hover { background: var(--ink-600); }
.ws-nav__panel-item .ico { color: var(--jade-500); flex: 0 0 auto; margin-top: 2px; }
.ws-nav__panel-item b { display: block; color: var(--mist); font-family: var(--font-display); font-size: 0.92rem; font-weight: 600; }
.ws-nav__panel-item span { font-size: var(--fs-micro); color: var(--steel-300); line-height: 1.4; }

.ws-nav__toggle { display: none; background: none; border: 0; color: var(--mist); padding: 0.5rem; }

@media (max-width: 1100px) {
  .ws-nav__links {
    position: fixed; inset: var(--nav-h) 0 0 0; flex-direction: column;
    background: rgba(8,10,14,0.97); backdrop-filter: blur(20px);
    padding: var(--space-3) var(--gutter); gap: 0.3rem; overflow-y: auto;
    transform: translateX(100%); transition: transform var(--t-med) var(--ease-out);
    align-items: stretch;
  }
  .ws-nav__links.is-open { transform: translateX(0); }
  .ws-nav__link { font-size: 1.05rem; padding: 0.8rem 1rem; }
  .ws-nav__panel { position: static; transform: none; opacity: 1; visibility: visible; width: 100%; grid-template-columns: 1fr; background: transparent; border: 0; box-shadow: none; padding: 0 0 0 0.5rem; }
  .ws-nav__toggle { display: inline-flex; }
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.55rem;
  font-family: var(--font-display); font-weight: 600; font-size: 0.95rem;
  padding: 0.85rem 1.5rem; border-radius: var(--r-pill);
  border: 1px solid transparent; transition: all var(--t-fast) var(--ease-out);
  letter-spacing: 0.01em; line-height: 1;
}
.btn .ico { transition: transform var(--t-fast); }
.btn:hover .ico { transform: translateX(3px); }
.btn--primary {
  background: var(--grad-jade); color: var(--ink-900);
  box-shadow: var(--glow-jade-soft);
}
.btn--primary:hover { box-shadow: var(--glow-jade); transform: translateY(-2px); }
.btn--ghost { border-color: var(--ink-450); color: var(--mist); background: rgba(255,255,255,0.02); }
.btn--ghost:hover { border-color: var(--jade-500); color: var(--jade-400); }
.btn--verm { background: var(--grad-dawn); color: var(--ink-900); box-shadow: var(--glow-verm); }
.btn--verm:hover { transform: translateY(-2px); }
.btn--lg { padding: 1.05rem 2rem; font-size: 1.05rem; }

/* ---------- CARDS ---------- */
.card {
  background: linear-gradient(180deg, var(--ink-700) 0%, var(--ink-800) 100%);
  border: var(--border-hair); border-radius: var(--r-lg);
  padding: var(--space-4); box-shadow: var(--shadow-card);
  transition: transform var(--t-med) var(--ease-out), border-color var(--t-med), box-shadow var(--t-med);
  position: relative; overflow: hidden;
}
.card:hover { transform: translateY(-5px); border-color: var(--ink-450); box-shadow: var(--shadow-lift); }
/* top accent line that lights on hover */
.card--lit::before {
  content: ""; position: absolute; inset: 0 0 auto 0; height: 2px;
  background: var(--grad-jade); transform: scaleX(0); transform-origin: left;
  transition: transform var(--t-med) var(--ease-blade);
}
.card--lit:hover::before { transform: scaleX(1); }
.card__ico {
  width: 48px; height: 48px; border-radius: var(--r-md);
  display: grid; place-items: center; margin-bottom: var(--space-2);
  background: var(--jade-ink); color: var(--jade-500); border: 1px solid rgba(52,245,163,0.2);
}
.card__ico--verm { background: var(--verm-ink); color: var(--verm-500); border-color: rgba(255,77,77,0.2); }
.card h3 { margin-bottom: 0.4rem; }
.card p { font-size: 0.95rem; color: var(--steel-300); }
.card__link { font-family: var(--font-display); font-size: 0.85rem; color: var(--jade-500); display: inline-flex; align-items: center; gap: 0.4rem; margin-top: var(--space-2); }
.card__link .ico { transition: transform var(--t-fast); }
.card:hover .card__link .ico { transform: translateX(4px); }

/* feature tag chips */
.chip {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: var(--fs-micro); font-family: var(--font-display); letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--steel-200);
  padding: 0.35rem 0.75rem; border-radius: var(--r-pill);
  background: var(--ink-600); border: var(--border-hair);
}
.chip--jade { color: var(--jade-400); border-color: rgba(52,245,163,0.25); background: var(--jade-ink); }

/* ---------- DEVICE FRAMES (for screenshots) ---------- */
/* 16:9 TV frame */
.frame-tv {
  position: relative; border-radius: var(--r-md);
  background: #020304; padding: 14px;
  border: 1px solid var(--ink-500);
  box-shadow: var(--shadow-lift), inset 0 0 0 1px rgba(255,255,255,0.03);
}
.frame-tv::after { /* screen glow */
  content: ""; position: absolute; inset: 14px; border-radius: 6px;
  box-shadow: inset 0 0 60px rgba(52,245,163,0.06); pointer-events: none;
}
.frame-tv__screen { border-radius: 6px; overflow: hidden; aspect-ratio: 16/9; background: var(--ink-800); }
.frame-tv__screen img { width: 100%; height: 100%; object-fit: cover; }

/* browser chrome frame */
.frame-browser {
  border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--ink-500);
  background: var(--ink-700); box-shadow: var(--shadow-lift);
}
.frame-browser__bar { display: flex; align-items: center; gap: 0.4rem; padding: 0.7rem 0.9rem; background: var(--ink-600); border-bottom: 1px solid var(--ink-500); }
.frame-browser__dot { width: 11px; height: 11px; border-radius: 50%; background: var(--ink-450); }
.frame-browser__dot:nth-child(1) { background: #ff5f57; }
.frame-browser__dot:nth-child(2) { background: #febc2e; }
.frame-browser__dot:nth-child(3) { background: #28c840; }
.frame-browser__url { margin-left: 0.6rem; font-size: var(--fs-micro); color: var(--steel-400); background: var(--ink-700); padding: 0.25rem 0.8rem; border-radius: var(--r-pill); flex: 1; }
.frame-browser__body { background: var(--ink-800); }
.frame-browser__body img { width: 100%; display: block; }

/* paper / portrait frame */
.frame-paper {
  background: #fff; border-radius: 4px; overflow: hidden;
  box-shadow: var(--shadow-lift); aspect-ratio: 8.5/11;
}
.frame-paper img { width: 100%; height: 100%; object-fit: cover; }

/* generic placeholder for pre-screenshot state */
.shot-placeholder {
  display: grid; place-items: center; gap: 0.5rem; min-height: 220px;
  background:
    repeating-linear-gradient(45deg, var(--ink-700) 0 12px, var(--ink-600) 12px 24px);
  color: var(--steel-400); font-family: var(--font-display); font-size: var(--fs-small);
  text-align: center; padding: var(--space-3); border-radius: 6px;
}
.shot-placeholder .ico { color: var(--jade-700); }

/* ---------- STAT / METRIC ---------- */
.stat { text-align: center; }
.stat__num { font-family: var(--font-display); font-size: clamp(2.2rem,4vw,3.4rem); font-weight: 700; color: var(--mist); line-height: 1; }
.stat__num .unit { color: var(--jade-500); }
.stat__label { font-size: var(--fs-small); color: var(--steel-300); margin-top: 0.5rem; letter-spacing: 0.04em; }

/* ---------- DIVIDER: ink-brush / blade ---------- */
.rule-blade { height: 1px; background: linear-gradient(90deg, transparent, var(--ink-450) 30%, var(--jade-700) 50%, var(--ink-450) 70%, transparent); border: 0; margin-block: var(--space-5); }

/* ---------- FOOTER ---------- */
.ws-footer { background: var(--ink-850); border-top: 1px solid var(--ink-500); padding-block: var(--space-6) var(--space-4); position: relative; z-index: 2; }
.ws-footer__grid { display: grid; grid-template-columns: 1.6fr repeat(3, 1fr); gap: var(--space-4); }
@media (max-width: 820px) { .ws-footer__grid { grid-template-columns: 1fr 1fr; } }
.ws-footer h4 { font-size: var(--fs-small); letter-spacing: 0.14em; text-transform: uppercase; color: var(--steel-200); margin-bottom: var(--space-2); }
.ws-footer a { display: block; color: var(--steel-300); font-size: var(--fs-small); padding: 0.3rem 0; transition: color var(--t-fast); }
.ws-footer a:hover { color: var(--jade-400); }
.ws-footer__tagline { color: var(--steel-300); font-size: var(--fs-small); max-width: 34ch; margin-top: var(--space-2); }
.ws-footer__bottom { margin-top: var(--space-5); padding-top: var(--space-3); border-top: 1px solid var(--ink-500); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; color: var(--steel-400); font-size: var(--fs-micro); }

/* ---------- CTA band ---------- */
.cta-band {
  background: var(--grad-hero); border: 1px solid var(--ink-500);
  border-radius: var(--r-lg); padding: var(--space-6) var(--space-4); text-align: center;
  position: relative; overflow: hidden;
}
.cta-band::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(600px 300px at 50% 120%, rgba(52,245,163,0.14), transparent 70%);
}

/* ---------- PAGE HERO (interior pages) ---------- */
.page-hero { padding-top: calc(var(--nav-h) + var(--space-6)); padding-bottom: var(--space-5); background: var(--grad-hero); border-bottom: 1px solid var(--ink-500); position: relative; overflow: hidden; }
.page-hero__inner { max-width: 760px; }
.page-hero h1 { font-size: var(--fs-h1); margin-bottom: var(--space-2); }

/* ---------- A/B VARIANT SWITCHER ---------- */
.ws-ab {
  position: fixed; right: 20px; bottom: 20px; z-index: 70;
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: rgba(8, 10, 14, 0.85); backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--ink-500); border-radius: var(--r-pill);
  padding: 0.35rem 0.4rem 0.35rem 0.85rem; box-shadow: var(--shadow-lift);
  font-family: var(--font-display); font-size: var(--fs-micro); letter-spacing: 0.14em;
}
.ws-ab__label { color: var(--steel-400); }
.ws-ab__pill {
  display: inline-grid; place-items: center; min-width: 28px; height: 28px;
  border-radius: 50%; background: var(--jade-500); color: var(--ink-900);
  font-weight: 700; font-size: 0.85rem; box-shadow: var(--glow-jade-soft);
}
.ws-ab__pill--alt {
  background: var(--ink-700); color: var(--steel-200); border: 1px solid var(--ink-450);
  text-decoration: none; transition: all var(--t-fast);
  box-shadow: none;
}
.ws-ab__pill--alt:hover { background: var(--vermillion); background: var(--verm-ink); color: var(--verm-500); border-color: var(--verm-500); }
@media (max-width: 620px) {
  .ws-ab { right: 12px; bottom: 12px; padding: 0.3rem 0.35rem 0.3rem 0.7rem; }
  .ws-ab__label { display: none; }
}

/* ---------- PLATFORM TAG-LINE (per-app variety intro thread) ---------- */
.platform-line {
  display: inline-flex; align-items: center; gap: 0.5rem; flex-wrap: wrap;
  font-family: 'JetBrains Mono', monospace, system-ui;
  font-size: var(--fs-micro); letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--steel-300); margin-bottom: var(--space-2);
}
.platform-line span {
  padding: 0.3rem 0.65rem; border-radius: var(--r-pill);
  background: var(--ink-700); border: var(--border-hair); color: var(--steel-200);
}
.platform-line span.is-num   { color: var(--gold-400); border-color: rgba(232,196,119,0.3); background: rgba(232,196,119,0.06); }
.platform-line span.is-platform { color: var(--jade-400); border-color: rgba(52,245,163,0.3); background: var(--jade-ink); }
.platform-line .sep { color: var(--steel-500, var(--steel-400)); padding: 0 0.1rem; }

/* relationship pill row */
.rel-row { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; font-family: var(--font-display); font-size: var(--fs-small); color: var(--steel-300); }
.rel-row .node { padding: 0.5rem 1rem; border-radius: var(--r-pill); border: var(--border-hair); background: var(--ink-700); color: var(--steel-100); }
.rel-row .node.is-self { border-color: var(--jade-500); color: var(--jade-400); box-shadow: var(--glow-jade-soft); }
.rel-row .arrow { color: var(--jade-600); }

/* ---------- Manifest-driven screenshot swap ---------- */
.rw-shot {
  display: block; width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  background: var(--ink-800);
}
.frame-paper .rw-shot,
.frame-browser__body .rw-shot { object-fit: contain; object-position: top; }
