/* ------------------------------------------------------------------
   Guignol — marketing site
   Tokens mirror src/renderer/src/styles/global.css so the site and
   the Electron app share one palette pixel-for-pixel.
   ------------------------------------------------------------------ */

:root {
  --color-bg:          #f8fafc;
  --color-bg-panel:    #f1f4f8;
  --color-bg-alt:      #eef1f5;
  --color-fg:          #0f172a;
  --color-fg-dim:      #475569;
  --color-fg-muted:    #8795a8;
  --color-fg-faint:    #cfd6df;
  --color-accent:      #2d5a94;
  --color-accent-dim:  #3a6fb5;
  --color-highlight:   rgba(232, 184, 58, 0.38);

  --color-dark-bg:     #0f1419;
  --color-dark-fg:     #e6edf3;
  --color-dark-dim:    #9da8b5;
  --color-dark-muted:  #6b7685;

  --tracking-caps:     0.14em;

  --font-sans:  'Space Grotesk', -apple-system, BlinkMacSystemFont, 'Inter', system-ui, sans-serif;
  --font-serif: 'Iowan Old Style', 'Charter', 'Georgia', serif;
  --font-mono:  'SF Mono', 'JetBrains Mono', Menlo, Consolas, monospace;
}

/* Reset -------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--color-fg);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
pre, blockquote { margin: 0; }

/* Inline code — used inside body copy and bullet lists */
code {
  font-family: var(--font-mono);
  font-size: 0.86em;
  padding: 1px 6px;
  background: var(--color-bg-alt);
  border-radius: 3px;
  color: var(--color-fg);
  word-break: break-word;
}

/* Layout ------------------------------------------------------------- */
.container {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 28px;
}
.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.two-col-reverse .col-visual { order: -1; }
@media (max-width: 820px) {
  .two-col { grid-template-columns: 1fr; gap: 48px; }
  .two-col-reverse .col-visual { order: 0; }
}

/* Typography --------------------------------------------------------- */
.eyebrow, .label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--color-fg-muted);
  font-weight: 500;
  margin: 0 0 20px;
}

.h1 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(40px, 6vw, 64px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  margin: 0 0 28px;
  color: var(--color-fg);
}
.h1 em { font-style: italic; color: var(--color-accent); }

.h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1.15;
  letter-spacing: -0.005em;
  margin: 0 0 20px;
  color: var(--color-fg);
}

.lede {
  font-family: var(--font-serif);
  font-size: 20px;
  line-height: 1.55;
  color: var(--color-fg-dim);
  max-width: 640px;
  margin: 0 0 36px;
}
.body {
  font-family: var(--font-serif);
  font-size: 18px;
  line-height: 1.65;
  color: var(--color-fg-dim);
  max-width: 560px;
}

/* Nav ---------------------------------------------------------------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 10;
  border-bottom: 1px solid var(--color-fg-faint);
  background: rgba(248, 250, 252, 0.82);
  backdrop-filter: saturate(1.4) blur(10px);
  -webkit-backdrop-filter: saturate(1.4) blur(10px);
}
.nav-inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 16px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand-mark {
  width: 28px;
  height: 28px;
  border-radius: 6px;
}
.brand-name {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.nav-links { display: flex; gap: 32px; }
.nav-links a {
  font-size: 13px;
  color: var(--color-fg-dim);
  letter-spacing: 0.01em;
  transition: color 160ms;
}
.nav-links a:hover { color: var(--color-accent); }
@media (max-width: 560px) {
  .nav-links { gap: 18px; }
  .nav-links a:not(:last-child) { display: none; }
}

/* Buttons ------------------------------------------------------------ */
.cta { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.01em;
  border-radius: 2px;
  border: 1px solid transparent;
  transition: background 180ms, color 180ms, border-color 180ms, transform 180ms;
  cursor: pointer;
}
.btn-lg { padding: 16px 32px; font-size: 15px; }
.btn-primary {
  background: var(--color-accent);
  color: var(--color-bg);
}
.btn-primary:hover {
  background: var(--color-fg);
  transform: translateY(-1px);
}
.btn-ghost {
  color: var(--color-fg-dim);
  border-color: var(--color-fg-faint);
}
.btn-ghost:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

/* Hero --------------------------------------------------------------- */
.hero {
  padding: 104px 0 120px;
  border-bottom: 1px solid var(--color-fg-faint);
  position: relative;
  overflow: hidden;
}
.hero::before {
  /* subtle diagonal rule, like a newspaper header ornament */
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 240px;
  height: 1px;
  background: var(--color-fg-faint);
  transform: translateY(56px);
}
.hero-meta {
  margin-top: 40px;
  font-size: 13px;
  letter-spacing: 0.01em;
  color: var(--color-fg-muted);
  max-width: 640px;
}

/* Hero product shot: a large screenshot below the hero copy.
   Max-width is narrower than .container so it feels framed, not poster-pasted. */
.hero-shot {
  margin: 72px auto 0;
  padding: 0 28px;
  max-width: 1080px;
}
.hero-shot img {
  width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 820px) {
  .hero-shot { margin-top: 56px; padding: 0 16px; }
}

/* Sections ----------------------------------------------------------- */
.section {
  padding: 96px 0;
  border-bottom: 1px solid var(--color-fg-faint);
}
.section-alt {
  background: var(--color-bg-panel);
}
.section-dark {
  background: var(--color-dark-bg);
  color: var(--color-dark-fg);
  border-color: transparent;
}
.section-dark .label { color: var(--color-dark-muted); }
.section-dark .h2    { color: var(--color-dark-fg); }
.section-dark .h2 em { color: #5b9cee; font-style: italic; }
.section-dark .body  { color: var(--color-dark-dim); }
.section-dark code {
  background: rgba(255, 255, 255, 0.07);
  color: var(--color-dark-fg);
}
.section-dark .bullets { color: var(--color-dark-dim); }
.section-dark .bullets li { border-color: rgba(255, 255, 255, 0.08); }
.section-dark .bullets li:last-child { border-bottom-color: rgba(255, 255, 255, 0.08); }
.section-dark .bullets li::before { background: #5b9cee; }
.section-dark .bullets strong { color: var(--color-dark-fg); }
.section-dark a {
  color: #5b9cee;
  border-bottom: 1px solid rgba(91, 156, 238, 0.35);
  transition: color 160ms, border-color 160ms;
}
.section-dark a:hover {
  color: var(--color-dark-fg);
  border-bottom-color: var(--color-dark-fg);
}

.section-quote {
  background: var(--color-bg-panel);
  padding: 80px 0;
}

/* Screenshot frame — applied to <figure> wrappers around <img>.
   Matches the hero shot's border/shadow so all product shots share one look. */
.shot-frame {
  margin: 0;
  padding: 0;
}
.shot-frame img {
  width: 100%;
  height: auto;
  display: block;
}
/* Wide variant: centered full-width-of-container shot used between a heading and cards. */
.shot-wide {
  margin: 40px 0 56px;
}

/* Bullet lists in feature body copy */
.bullets {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  font-family: var(--font-serif);
  font-size: 16px;
  line-height: 1.55;
  color: var(--color-fg-dim);
  max-width: 560px;
}
.bullets li {
  position: relative;
  padding: 6px 0 6px 20px;
  border-top: 1px solid var(--color-fg-faint);
}
.bullets li:last-child { border-bottom: 1px solid var(--color-fg-faint); }
.bullets li::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 17px;
  width: 6px;
  height: 2px;
  background: var(--color-accent);
}
.bullets strong { color: var(--color-fg); font-weight: 600; }
.bullets em { font-style: italic; color: var(--color-fg); }

/* Terminal ----------------------------------------------------------- */
.terminal {
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.75;
  background: #000;
  color: var(--color-dark-fg);
  padding: 26px 30px;
  border-radius: 4px;
  white-space: pre-wrap;
  word-wrap: break-word;
  border: 1px solid #222;
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
}
.terminal .p { color: #7dd3a6; }            /* prompt */
.terminal .s { color: #f3b95c; }            /* string */
.terminal .d { color: var(--color-dark-muted); font-style: italic; }
.terminal .h {
  background: rgba(232, 184, 58, 0.22);
  color: #fde68a;
  padding: 0 3px;
  border-bottom: 1px solid rgba(232, 184, 58, 0.7);
}

/* Cards -------------------------------------------------------------- */
.cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 48px;
}
@media (max-width: 820px) {
  .cards { grid-template-columns: 1fr; }
}
.card {
  border: 1px solid var(--color-fg-faint);
  background: var(--color-bg-panel);
  padding: 28px 28px 32px;
  border-radius: 3px;
  transition: border-color 200ms, transform 200ms, box-shadow 200ms;
}
.card:hover {
  border-color: var(--color-accent);
  transform: translateY(-2px);
  box-shadow: 0 10px 30px -20px rgba(15, 23, 42, 0.3);
}
.card-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--color-accent);
  margin: 0 0 14px;
  font-weight: 600;
}
.card-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 12px;
  line-height: 1.3;
  color: var(--color-fg);
}
.card-body {
  font-family: var(--font-serif);
  font-size: 16px;
  color: var(--color-fg-dim);
  line-height: 1.55;
  margin: 0;
}

/* Manifesto ---------------------------------------------------------- */
.manifesto {
  font-family: var(--font-serif);
  font-size: clamp(22px, 2.4vw, 28px);
  line-height: 1.45;
  color: var(--color-fg);
  max-width: 820px;
  border-left: 2px solid var(--color-accent);
  padding: 4px 0 4px 28px;
  margin: 12px 0 0;
}
.manifesto em {
  font-style: italic;
  color: var(--color-accent);
}

/* Download ----------------------------------------------------------- */
.section-download {
  background: var(--color-bg-panel);
  padding: 104px 0;
}
.download-row {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin: 28px 0 14px;
}
.download-meta {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--color-fg-muted);
  margin: 0;
}
.tiny {
  font-size: 13px;
  color: var(--color-fg-dim);
  margin: 0;
}
.tiny a {
  color: var(--color-accent);
  border-bottom: 1px solid var(--color-accent-dim);
}

/* Footer ------------------------------------------------------------- */
.footer {
  padding: 56px 0 72px;
  background: var(--color-bg);
  border-top: 1px solid var(--color-fg-faint);
}
.footer-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 32px;
  align-items: center;
}
@media (max-width: 820px) {
  .footer-inner { grid-template-columns: 1fr; gap: 14px; }
}
.footer-brand {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 600;
  margin: 0;
}
.footer-note {
  font-size: 13px;
  color: var(--color-fg-dim);
  margin: 0;
}
.footer-note a { border-bottom: 1px solid var(--color-fg-faint); }
.footer-note a:hover { border-bottom-color: var(--color-accent); color: var(--color-accent); }
.footer-links { display: flex; gap: 24px; }
.footer-links a {
  font-size: 13px;
  color: var(--color-fg-dim);
  transition: color 160ms;
}
.footer-links a:hover { color: var(--color-accent); }

/* Reduced motion ----------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}
