/* Marketing-site specific styles. Tokens live in colors_and_type.css. */
@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--bsd-font-body);
  font-size: var(--bsd-fs-root);
  line-height: var(--bsd-lh-body);
  background: var(--bsd-offwhite);
  color: var(--bsd-text);
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

.container {
  max-width: var(--bsd-max);
  margin: 0 auto;
  padding: 0 var(--bsd-pad-x);
}

/* --- HERO (dark) ---------------------------------------------- */
.hero-dark { background: var(--bsd-dark); }
.hero-dark header { padding: 1.5rem 0; border-bottom: 1px solid var(--bsd-dark-divider); }
.hero-dark header .container { display: flex; justify-content: space-between; align-items: center; }
.logo { display: flex; flex-direction: column; line-height: 1; gap: 0.1rem; }
.logo-bespoke { font-family: var(--bsd-font-logo); font-weight: 700; font-size: var(--bsd-fs-logo); color: #fff; letter-spacing: var(--bsd-ls-logo); line-height: 1; }
.logo-sub { font-family: var(--bsd-font-logo); font-weight: 300; font-size: var(--bsd-fs-logo-sub); color: #888; text-transform: uppercase; letter-spacing: var(--bsd-ls-logo-sub); line-height: 1; }
.hero-dark nav a { color: var(--bsd-dark-text-4); text-decoration: none; font-size: 0.875rem; margin-left: 1.5rem; transition: color var(--bsd-t-fast); }
.hero-dark nav a:hover { color: #fff; }

.hero-content { padding: 6rem 0 3rem; }
.hero-eyebrow { display: inline-block; color: var(--bsd-accent); font-size: var(--bsd-fs-eyebrow); font-weight: 700; letter-spacing: var(--bsd-ls-eyebrow); text-transform: uppercase; margin-bottom: 1.5rem; }
[data-theme="cyberpunk"] .hero-eyebrow { color: var(--bsd-cp-yellow); }

.hero-content h1 { font-size: clamp(2.75rem, 7.5vw, 4.75rem); font-weight: var(--bsd-fw-h1); line-height: var(--bsd-lh-tight); letter-spacing: var(--bsd-ls-h1); color: #fff; max-width: 720px; margin-bottom: 1.25rem; }
.hero-content h1 em { font-style: normal; color: var(--bsd-accent); }
[data-theme="cyberpunk"] .hero-content h1 em {
  background: linear-gradient(90deg, var(--bsd-cp-yellow) 0%, var(--bsd-cp-magenta) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

.hero-content .lead { font-size: var(--bsd-fs-lead); color: var(--bsd-dark-text-3); max-width: 480px; margin-bottom: 2.25rem; line-height: var(--bsd-lh-lead); }
.hero-ctas { display: flex; align-items: center; gap: 1rem; margin-bottom: 4rem; flex-wrap: wrap; }

.btn-primary { display: inline-block; background: var(--bsd-accent); color: var(--bsd-dark); font-weight: 700; font-size: 0.9rem; padding: 0.85rem 1.75rem; border-radius: var(--bsd-radius); text-decoration: none; letter-spacing: -0.01em; transition: opacity var(--bsd-t-fast); cursor: pointer; border: 0; }
.btn-primary:hover { opacity: 0.88; }
[data-theme="cyberpunk"] .btn-primary { background: var(--bsd-cp-magenta); color: #fff; }
.btn-ghost { color: var(--bsd-dark-text-4); font-size: 0.9rem; text-decoration: none; transition: color var(--bsd-t-fast); background: none; border: 0; cursor: pointer; padding: 0; }
.btn-ghost:hover { color: #fff; }

/* --- THEME PICKER --------------------------------------------- */
.theme-picker { border-top: 1px solid var(--bsd-dark-divider); padding: 1.75rem 0; }
.picker-label { font-size: 0.7rem; font-weight: 600; color: var(--bsd-dark-text-5); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 1rem; }
.themes { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.theme-btn { display: flex; align-items: center; gap: 0.6rem; background: var(--bsd-dark-card-bg); border: 1px solid var(--bsd-dark-card-bd); border-radius: var(--bsd-radius-md); padding: 0.6rem 0.9rem; cursor: pointer; transition: border-color var(--bsd-t-fast), background var(--bsd-t-fast); text-align: left; }
.theme-btn:hover { border-color: #444; }
.theme-btn.active { border-color: var(--active-accent); box-shadow: 0 0 0 1px var(--active-accent); }
.theme-swatch { width: 0.75rem; height: 0.75rem; border-radius: 50%; flex-shrink: 0; }
.theme-btn .name { font-size: 0.8rem; font-weight: 600; color: #ccc; white-space: nowrap; }
.theme-btn .tagline { font-size: 0.7rem; color: #555; white-space: nowrap; }
.theme-btn-inner { display: flex; flex-direction: column; }
.picker-footnote { margin-top: 1rem; font-size: 0.75rem; color: var(--bsd-dark-text-5); }
.picker-footnote span { color: var(--bsd-accent); }
[data-theme="cyberpunk"] .picker-footnote span { color: var(--bsd-cp-magenta); }

/* --- SECTIONS (light) ----------------------------------------- */
section { padding: var(--bsd-pad-y) 0; }
section + section { border-top: 1px solid var(--bsd-border); }
h2 { font-size: var(--bsd-fs-h2); font-weight: var(--bsd-fw-h2); letter-spacing: var(--bsd-ls-h2); margin-bottom: 0.4rem; }
.section-sub { color: var(--bsd-muted); margin-bottom: 2rem; }

/* Steps */
.steps { list-style: none; }
.step { display: grid; grid-template-columns: 3rem 1fr; gap: 1.25rem; padding: 1.5rem 0; border-bottom: 1px solid var(--bsd-border); align-items: start; }
.step:first-child { border-top: 1px solid var(--bsd-border); }
.step-num { font-size: 0.75rem; font-weight: 700; color: var(--bsd-accent); padding-top: 0.2rem; letter-spacing: 0.05em; }
[data-theme="cyberpunk"] .step-num { color: var(--bsd-cp-accent); }
.step h3 { font-size: 1rem; font-weight: 600; margin-bottom: 0.2rem; }
.step p { color: var(--bsd-muted); font-size: 0.95rem; }

/* Included */
.included-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 1px; background: var(--bsd-border); border: 1px solid var(--bsd-border); border-radius: var(--bsd-radius-lg); overflow: hidden; }
.included-item { background: var(--bsd-offwhite); padding: 1.5rem; }
.included-ic { width: 2.75rem; height: 2.75rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-bottom: 1rem; color: var(--bsd-dark); background: var(--bsd-accent); }
[data-theme="cyberpunk"] .included-ic { color: var(--bsd-dark); background: linear-gradient(135deg, var(--bsd-cp-yellow) 0%, var(--bsd-cp-magenta) 100%); }
.included-item h3 { font-size: 0.95rem; font-weight: 600; margin-bottom: 0.2rem; }
.included-item p { font-size: 0.875rem; color: var(--bsd-muted); line-height: 1.5; }

/* Pricing */
.pricing-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.price-card { border: 1px solid var(--bsd-border); border-radius: var(--bsd-radius-lg); padding: 2rem; }
.price-card.featured { border-color: var(--bsd-accent); background: #fff; }
[data-theme="cyberpunk"] .price-card.featured { border-color: var(--bsd-cp-magenta); }
.card-label { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--bsd-muted); margin-bottom: 0.75rem; }
.price-card .amount { font-size: 3.75rem; font-weight: 800; letter-spacing: -0.04em; line-height: 1; margin-bottom: 1rem; }
.price-card.featured .amount { color: var(--bsd-accent); }
[data-theme="cyberpunk"] .price-card.featured .amount { color: var(--bsd-cp-magenta); }
.price-card .amount sub { font-size: 1.5rem; color: var(--bsd-muted); vertical-align: baseline; }
.price-card p { color: var(--bsd-muted); font-size: 0.9rem; line-height: 1.55; }

/* Trust band — "Built secure. Built to be found." Sits right after hero. */
.trust-band { background: var(--bsd-dark); padding: 3rem 0 3.25rem; border-top: 1px solid var(--bsd-dark-divider); }
.trust-kick { display: block; width: 2.5rem; height: 3px; border-radius: 2px; margin-bottom: 1rem; background: var(--bsd-accent); }
[data-theme="cyberpunk"] .trust-kick { background: linear-gradient(90deg, var(--bsd-cp-yellow) 0%, var(--bsd-cp-magenta) 100%); }
.trust-band h2 { color: #fff; font-size: 1.65rem; font-weight: 700; letter-spacing: -0.025em; margin-bottom: 0.35rem; }
.trust-sub { color: #8d8d96; font-size: 0.95rem; margin-bottom: 2rem; }
.trust-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.75rem; }
.trust-claim { display: flex; flex-direction: column; gap: 0.6rem; }
.trust-ic { width: 2.5rem; height: 2.5rem; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--bsd-accent); background: color-mix(in srgb, var(--bsd-accent) 14%, transparent); border: 1px solid color-mix(in srgb, var(--bsd-accent) 30%, transparent); margin-bottom: 0.25rem; }
[data-theme="cyberpunk"] .trust-ic { color: var(--bsd-cp-accent); background: color-mix(in srgb, var(--bsd-cp-accent) 14%, transparent); border-color: color-mix(in srgb, var(--bsd-cp-accent) 35%, transparent); }
body[data-fx-glow="on"] .trust-ic { box-shadow: 0 0 14px -4px var(--fx-cta-glow); }
.trust-claim h3 { color: #fff; font-size: 1rem; font-weight: 600; margin: 0; letter-spacing: -0.005em; }
.trust-claim p { color: #b7b7c1; font-size: 0.875rem; line-height: 1.55; margin: 0; }

/* Contact / "Ready to get started" — terminal compose window */
.term { max-width: 660px; margin: 2.25rem auto 0; background: #0B0B0E; border: 1px solid #23232a; border-radius: 12px; overflow: hidden; box-shadow: 0 0 0 1px color-mix(in srgb, var(--bsd-accent) 16%, transparent), 0 30px 70px -30px var(--bsd-glow); }
.term-bar { display: flex; align-items: center; gap: 0.5rem; padding: 0.75rem 1rem; background: #141419; border-bottom: 1px solid #23232a; }
.term-dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.term-title { margin-left: 0.6rem; font-family: var(--font-mono); font-size: 0.75rem; color: #6c6c78; letter-spacing: 0.01em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.term-body { padding: 1.5rem 1.6rem 1.75rem; font-family: var(--font-mono); font-size: 0.85rem; line-height: 1.85; }
.term-cmt { color: #5c8d7a; }
.term-q { color: #d6d6e0; }
.term-q .pr { color: var(--bsd-accent); margin-right: 0.6rem; }
.term-cursor { display: inline-block; width: 8px; height: 16px; background: var(--bsd-accent); vertical-align: -3px; margin-left: 4px; box-shadow: 0 0 10px var(--bsd-accent); }
[data-theme="cyberpunk"] .term-cursor { background: var(--bsd-cp-magenta); box-shadow: 0 0 10px var(--bsd-cp-magenta); }
.term-cta { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 1.4rem; background: var(--bsd-accent); color: #0D0D10; font-family: var(--font-mono); font-weight: 700; font-size: 0.8rem; padding: 0.8rem 1.4rem; border-radius: 7px; text-decoration: none; box-shadow: 0 0 26px -6px var(--bsd-glow); }
[data-theme="cyberpunk"] .term-cta { background: linear-gradient(90deg, var(--bsd-cp-yellow) 0%, var(--bsd-cp-magenta) 100%); }
.term-email { margin-top: 1rem; font-family: var(--font-mono); font-size: 0.72rem; color: #6c6c78; }
.term-email a { color: var(--bsd-accent); text-decoration: none; }
[data-theme="cyberpunk"] .term-email a { color: var(--bsd-cp-accent); }

/* Footer */
.site-footer { background: var(--bsd-dark); border-top: 1px solid #1A1A1E; padding: 1.5rem 0; }
.site-footer p { color: var(--bsd-dark-text-5); font-size: 0.85rem; }
.site-footer a { color: var(--bsd-accent); text-decoration: none; }
[data-theme="cyberpunk"] .site-footer a { color: var(--bsd-cp-magenta); }

/* Work */
#work { background: var(--bsd-offwhite); }
#work h2 { font-size: 2rem; font-weight: 800; letter-spacing: -0.03em; color: var(--bsd-dark); margin-bottom: 0.5rem; }
#work .section-sub { margin-bottom: 2.5rem; }
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.work-card { background: #fff; border: 1px solid var(--bsd-border); border-radius: var(--bsd-radius-md); overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: box-shadow 0.2s, transform 0.2s; }
.work-card:hover { box-shadow: var(--bsd-shadow-card-hover); transform: translateY(-2px); }
.work-thumb { height: 160px; overflow: hidden; background: #1C3A5A; }
.work-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform var(--bsd-t-slow); }
.work-card:hover .work-thumb img { transform: scale(1.04); }
.work-body { padding: 1.25rem; flex: 1; }
.work-tag { display: inline-block; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bsd-muted); margin-bottom: 0.4rem; }
.work-body h3 { font-size: 1.05rem; font-weight: 700; color: var(--bsd-dark); margin-bottom: 0.35rem; }
.work-body p { font-size: 0.875rem; color: var(--bsd-muted); line-height: 1.5; margin-bottom: 0.75rem; }
.work-link { font-size: 0.8rem; font-weight: 700; color: var(--bsd-accent); text-decoration: none; }
[data-theme="cyberpunk"] .work-link { color: var(--bsd-cp-magenta); }

/* Project Highlight — Lemon-AID pro-bono co-brand (fixed palette) */
#highlight { background: var(--bsd-offwhite); }
.ph-card { display: grid; grid-template-columns: 0.85fr 1fr; border: 1px solid #0A0A0A; border-radius: 16px; overflow: hidden; box-shadow: 0 24px 60px -28px rgba(10,10,10,0.4); }
.ph-stage { position: relative; background: #0D0D10; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.5rem; padding: 3.5rem 2rem; min-height: 320px; background-image: radial-gradient(60% 60% at 50% 38%, rgba(232,213,71,0.10), transparent 70%); }
.ph-lockup { display: inline-flex; align-items: baseline; white-space: nowrap; color: #FAFAF7; font-weight: 800; font-size: clamp(1.7rem, 3.4vw, 2.4rem); letter-spacing: -0.045em; line-height: 1; }
.ph-wordmark { font-family: var(--bsd-font-logo); }
.ph-period { display: inline-flex; align-items: center; margin-left: 0.06em; transform: translateY(0.04em); }
.ph-fig { position: absolute; bottom: 1rem; left: 1.1rem; font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.16em; text-transform: uppercase; color: #6c6c5a; }
.ph-body { background: #FAFAF7; padding: 2.75rem 2.75rem 2.5rem; display: flex; flex-direction: column; }
.ph-eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; white-space: nowrap; font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: #9a8a1e; margin-bottom: 1rem; }
.ph-h2 { font-size: clamp(1.5rem, 2.6vw, 2rem); font-weight: 800; letter-spacing: -0.03em; line-height: 1.1; color: #0A0A0A; margin-bottom: 1rem; text-wrap: balance; }
.ph-lead { font-size: 0.95rem; line-height: 1.6; color: #44443c; margin-bottom: 1rem; }
.ph-prog { font-size: 0.95rem; line-height: 1.55; color: #0A0A0A; font-weight: 600; margin-bottom: 1.5rem; }
.ph-ctas { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.ph-btn { display: inline-flex; align-items: center; gap: 0.4rem; background: #E8D547; color: #0A0A0A; font-weight: 700; font-size: 0.9rem; padding: 0.8rem 1.6rem; border-radius: var(--bsd-radius); text-decoration: none; transition: transform var(--bsd-t-fast), box-shadow var(--bsd-t-fast); }
.ph-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 22px -8px rgba(232,213,71,0.8); }
.ph-apply { font-size: 0.9rem; font-weight: 600; color: #0A0A0A; text-decoration: none; border-bottom: 1px solid rgba(10,10,10,0.25); padding-bottom: 1px; transition: border-color var(--bsd-t-fast); }
.ph-apply:hover { border-color: #0A0A0A; }
.ph-elig { margin-top: auto; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: #8a8a7e; padding-top: 1.25rem; border-top: 1px solid #E8E6DF; }

/* Work photo treatment — set by Tweaks (body[data-work]). Default: muted. */
.work-thumb { position: relative; }
.work-tint { position: absolute; inset: 0; pointer-events: none; opacity: 0; transition: opacity var(--bsd-t-med); }
.work-thumb img { transition: transform var(--bsd-t-slow), filter var(--bsd-t-med); }
body[data-work="muted"] .work-thumb img { filter: saturate(0.5) contrast(0.95) brightness(0.97); }
body[data-work="mono"] .work-thumb img { filter: grayscale(1) contrast(1.04) brightness(0.98); }
body[data-work="duotone"] .work-thumb { background: #0D0D10; }
body[data-work="duotone"] .work-thumb img { filter: grayscale(1) contrast(1.15) brightness(0.85); }
body[data-work="duotone"] .work-tint { opacity: 0.6; mix-blend-mode: screen; background: var(--bsd-duotone, linear-gradient(135deg, #00B3C8 0%, #C4006F 100%)); transition: opacity var(--bsd-t-med); }

@media (max-width: 640px) {
  .hero-dark nav { display: none; }
  .logo-bespoke { font-size: 1.5rem; }
  .hero-content { padding: 2.75rem 0 2rem; }
  .hero-content h1 { font-size: clamp(2.1rem, 9vw, 2.75rem); }
  .hero-ctas { flex-direction: column; align-items: flex-start; gap: 0.75rem; margin-bottom: 2.5rem; }
  section { padding: var(--bsd-pad-y-sm) 0; }
  .included-grid { grid-template-columns: 1fr; }
  .pricing-row { grid-template-columns: 1fr; }
  .price-card .amount { font-size: 3rem; }
  .work-grid { grid-template-columns: 1fr; }
  .term-body { font-size: 0.78rem; }
  .trust-grid { grid-template-columns: 1fr; gap: 1.25rem; }
  .ph-card { grid-template-columns: 1fr; }
  .ph-stage { min-height: 220px; padding: 2.5rem 1.5rem; }
  .ph-body { padding: 2rem 1.75rem; }
}
