:root {
  --color-bg: #f9f6f5;
  --color-primary: #4a2c2a;
  --color-primary-dark: #3f2524;
  --color-primary-on-bg: #4a2c2a;
  --color-on-primary: #ffffff;
  --color-accent: #e05a28;
  --color-accent-dark: #be4c22;
  --color-accent-contrast: #111111;
  --color-text: #000000;
  --color-muted: #8c8c8c;
  --color-surface: #f9f6f6;
  --color-border: #b2b2b2;
  --font-heading: 'Abril Fatface', Georgia, 'Times New Roman', serif;
  --font-body: ui-monospace, 'SF Mono', 'Cascadia Code', Menlo, Consolas, monospace;
  --font-size-base: 1rem;
  --container-max: 1200px;
  --radius: 8px;
  --radius-lg: 16px;
  --radius-button: 8px;
  --spacing-sm: 0.35rem;
  --spacing-md: 0.7rem;
  --spacing-lg: 1.4rem;
  --spacing-xl: 2.8rem;
  --transition: 0.2s ease;
}
/* The dark-mode toggle swaps in a near-black page background, so the
   contrast-safe primary text color must be recomputed against it (the
   light-theme value can be too dark to read on the dark surface). */
.theme-dark { --color-primary-on-bg: #77615f; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: var(--font-body); font-size: var(--font-size-base);
  color: var(--color-text); background: var(--color-bg);
  line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--color-primary-on-bg); text-decoration: none; }
a:hover { color: var(--color-accent); }
ul, ol { list-style: none; }


html { height: 100%; }
body { display: flex; flex-direction: column; min-height: 100vh; }
.site-main-wrap { flex: 1 0 auto; }
.site-footer { flex-shrink: 0; margin-top: auto; }


h1, h2, h3, h4 { font-family: var(--font-heading); line-height: 1.2;
  color: var(--color-text); }
h1 { font-size: 2.5rem; margin-bottom: var(--spacing-md); }
h2 { font-size: 1.75rem; margin-bottom: var(--spacing-md); }
h3 { font-size: 1.25rem; margin-bottom: var(--spacing-sm); }
p { margin-bottom: var(--spacing-md); }


.page-section-37fa0b { max-width: var(--container-max); margin: 0 auto;
  padding: var(--spacing-xl) var(--spacing-lg); }
.page-intro { font-size: 1.125rem; color: var(--color-muted);
  max-width: 700px; margin-bottom: var(--spacing-xl); }


.site-header { background: var(--color-primary);
  color: var(--color-on-primary); padding: var(--spacing-md) var(--spacing-lg);
  position: sticky; top: 0; z-index: 100;
  box-shadow: 0 1px 0 rgba(0,0,0,0.12), 0 2px 10px rgba(0,0,0,0.06); }
.header-inner { max-width: var(--container-max); margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between; gap: var(--spacing-md); }
.header-brand { display: flex; align-items: center; }
.site-name { font-family: var(--font-heading); font-size: 1.25rem;
  font-weight: 700; color: var(--color-on-primary); }
.site-logo { height: 36px; width: auto; }
.logo-link { display: inline-flex; }
.main-nav .nav-list { display: flex; gap: var(--spacing-md); }
.main-nav .nav-link {
  color: color-mix(in srgb, var(--color-on-primary) 85%, transparent);
  font-size: 0.9rem; transition: color var(--transition); }
.main-nav .nav-link:hover { color: var(--color-on-primary); }
.header-actions { display: flex; align-items: center; gap: var(--spacing-sm); }
.header-cta { font-size: 0.85rem; padding: 0.4rem 1rem; }
.menu-toggle { display: none; background: none; border: none;
  color: var(--color-on-primary); font-size: 1.5rem; cursor: pointer; }


.hero { position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  color: #fff; text-align: center;
  padding: var(--spacing-xl) var(--spacing-lg); }
.hero-inner { max-width: 800px; margin: 0 auto; position: relative; z-index: 1; }
.hero-content { display: flex; flex-direction: column; align-items: center; }
.hero-headline { font-size: 3rem; color: #fff; margin-bottom: var(--spacing-md); }
.hero-subtitle { font-size: 1.25rem; opacity: 0.9; margin-bottom: var(--spacing-lg); }
.hero-actions { display: flex; gap: var(--spacing-md);
  justify-content: center; flex-wrap: wrap; }
/* On the coloured hero, buttons need their own contrast so text never
   matches the background (primary-on-primary would be invisible). */
.hero .btn-primary { background: var(--color-accent);
  color: var(--color-accent-contrast); }
.hero .btn-primary:hover { background: var(--color-accent-dark);
  color: var(--color-accent-contrast); }
.hero .btn-secondary { background: transparent; color: #fff;
  border: 2px solid rgba(255,255,255,0.8); }
.hero .btn-secondary:hover { background: #fff; color: var(--color-primary); }


/* ── Hero layout variants (hero_diversity.layout) ───────────────────────── */
.hero--centered-narrow .hero-inner { max-width: 680px; }
.hero--centered-narrow .hero-headline { font-size: 3.4rem;
  letter-spacing: -0.02em; }
.hero--split-left .hero-inner, .hero--split-right .hero-inner {
  max-width: var(--container-max); display: grid;
  grid-template-columns: 1.05fr 0.95fr; gap: var(--spacing-xl);
  align-items: center; text-align: left; }
.hero--split-left .hero-content, .hero--split-right .hero-content {
  align-items: flex-start; text-align: left; }
.hero--split-left .hero-actions, .hero--split-right .hero-actions {
  justify-content: flex-start; }
.hero--split-right .hero-content { order: 2; }
.hero--split-right .hero-media { order: 1; }

/* ── Hero media frame (split layouts) ───────────────────────────────────── */
.hero-media { width: 100%; }
.hero-media img { width: 100%; display: block; border-radius: var(--radius-lg);
  box-shadow: 0 20px 50px rgba(0,0,0,0.28); }
.hero-media--mockup { background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.25); border-radius: var(--radius-lg);
  padding: 1.6rem 0.75rem 0.75rem; position: relative; }
.hero-media--mockup::before { content: ""; position: absolute; top: 0.6rem;
  left: 0.9rem; width: 8px; height: 8px; border-radius: 50%;
  background: rgba(255,255,255,0.55);
  box-shadow: 14px 0 0 rgba(255,255,255,0.4), 28px 0 0 rgba(255,255,255,0.25); }
.hero-media--mockup img { border-radius: calc(var(--radius) - 2px);
  box-shadow: none; }

/* ── Hero background variants (hero_diversity.background) ────────────────── */
.hero--bg-gradient-diagonal { background:
  linear-gradient(135deg, var(--color-primary), var(--color-accent)); }
.hero--bg-gradient-vertical { background:
  linear-gradient(180deg, var(--color-primary), var(--color-accent)); }
.hero--bg-gradient-radial { background:
  radial-gradient(circle at 30% 20%, var(--color-accent),
    var(--color-primary) 70%); }
.hero--bg-mesh { background:
  radial-gradient(at 18% 22%,
    color-mix(in srgb, var(--color-accent) 75%, transparent), transparent 45%),
  radial-gradient(at 82% 14%,
    color-mix(in srgb, var(--color-primary) 70%, transparent), transparent 48%),
  radial-gradient(at 60% 88%,
    color-mix(in srgb, var(--color-accent) 55%, transparent), transparent 50%),
  var(--color-primary); }
.hero--bg-solid { background: var(--color-primary); }
.hero--bg-surface-light { background: var(--color-surface);
  color: var(--color-text); }
.hero--bg-surface-light .hero-headline { color: var(--color-primary-on-bg); }
.hero--bg-surface-light .hero-subtitle { color: var(--color-muted);
  opacity: 1; }
.hero--bg-surface-light .hero-eyebrow {
  background: color-mix(in srgb, var(--color-accent) 14%, transparent);
  color: var(--color-accent); }
.hero--bg-surface-light .btn-secondary { color: var(--color-primary-on-bg);
  border-color: var(--color-primary-on-bg); }
.hero--bg-surface-light .btn-secondary:hover { background: var(--color-primary);
  color: var(--color-on-primary); }
.hero--bg-surface-light .hero-note,
.hero--bg-surface-light .hero-trust__label { color: var(--color-muted); }

/* ── Hero decoration layer (hero_diversity.decor) — subtle, premium ─────── */
.hero--decor-grid::after { content: ""; position: absolute; inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(color-mix(in srgb, #fff 9%, transparent) 1px,
      transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, #fff 9%, transparent) 1px,
      transparent 1px);
  background-size: 40px 40px;
  -webkit-mask-image: radial-gradient(circle at 50% 40%, #000, transparent 75%);
  mask-image: radial-gradient(circle at 50% 40%, #000, transparent 75%); }
.hero--bg-surface-light.hero--decor-grid::after { background-image:
  linear-gradient(color-mix(in srgb, #000 7%, transparent) 1px, transparent 1px),
  linear-gradient(90deg, color-mix(in srgb, #000 7%, transparent) 1px,
    transparent 1px); }
.hero--decor-glow::after { content: ""; position: absolute; pointer-events: none;
  width: 60%; height: 140%; top: -40%; right: -10%;
  background: radial-gradient(circle,
    color-mix(in srgb, var(--color-accent) 55%, transparent), transparent 60%); }
.hero--decor-blob::before { content: ""; position: absolute; pointer-events: none;
  width: 420px; height: 420px; left: -120px; bottom: -160px; border-radius: 50%;
  background: color-mix(in srgb, var(--color-accent) 50%, transparent);
  filter: blur(90px); opacity: 0.55; }
.hero--decor-noise::after { content: ""; position: absolute; inset: 0;
  pointer-events: none; opacity: 0.06; background-image:
  url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ── Hero typography variants (hero_diversity.type) ─────────────────────── */
.hero--type-display .hero-headline { font-size: 3.75rem; font-weight: 800;
  line-height: 1.05; letter-spacing: -0.03em; }
.hero--type-gradient-text .hero-headline { background:
  linear-gradient(90deg, #fff, color-mix(in srgb, #fff 55%, var(--color-accent)));
  -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero--bg-surface-light.hero--type-gradient-text .hero-headline { background:
  linear-gradient(90deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ── Hero eyebrow / CTA note / trust strip ──────────────────────────────── */
.hero-eyebrow { display: inline-block; align-self: center;
  margin-bottom: var(--spacing-sm); padding: 0.3rem 0.85rem; border-radius: 999px;
  font-size: 0.8rem; font-weight: 600; letter-spacing: 0.04em;
  text-transform: uppercase; background: rgba(255,255,255,0.18); color: #fff; }
.hero--split-left .hero-eyebrow, .hero--split-right .hero-eyebrow {
  align-self: flex-start; }
.hero-note { margin-top: var(--spacing-sm); font-size: 0.85rem; opacity: 0.85; }
.hero-trust { display: flex; align-items: center; gap: 0.5rem;
  margin-top: var(--spacing-md); flex-wrap: wrap; }
.hero-trust__stars { color: #ffd166; letter-spacing: 1px; }
.hero-trust__label { font-size: 0.85rem; opacity: 0.9; }

/* ── Hero action-style variants (hero_diversity.actions) ────────────────── */
.hero-actions--stacked { flex-direction: column; align-items: center; }
.hero--split-left .hero-actions--stacked,
.hero--split-right .hero-actions--stacked { align-items: flex-start; }


.benefits { background: var(--color-surface);
  padding: var(--spacing-xl) var(--spacing-lg); }
.benefits-grid-37fa0b { max-width: var(--container-max); margin: 0 auto;
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); }
.benefit-item-37fa0b { text-align: center; padding: var(--spacing-lg);
  background: var(--color-bg); border-radius: var(--radius);
  box-shadow: 0 1px 3px rgba(0,0,0,0.08); }


.features-grid-37fa0b { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); margin-top: var(--spacing-lg); }
.feature-card-37fa0b { padding: var(--spacing-lg);
  border: 1px solid var(--color-border); border-radius: var(--radius);
  transition: box-shadow var(--transition); }
.feature-card-37fa0b:hover { box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.feature-title-37fa0b { color: var(--color-primary-on-bg); }


.download-grid-37fa0b { display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--spacing-lg); margin-top: var(--spacing-lg); }
.download-card-37fa0b { text-align: center; padding: var(--spacing-xl) var(--spacing-lg);
  border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.download-card-37fa0b h3 { margin-bottom: var(--spacing-md); }
.btn-download { margin-bottom: var(--spacing-sm); }
.platform-requirements { font-size: 0.85rem; color: var(--color-muted); }
.installation-note { margin-top: var(--spacing-xl); padding: var(--spacing-lg);
  background: var(--color-surface); border-radius: var(--radius);
  text-align: center; }


.pricing-grid-37fa0b { display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--spacing-lg); margin-top: var(--spacing-lg);
  align-items: start; }
.pricing-card-37fa0b { padding: var(--spacing-xl) var(--spacing-lg);
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  text-align: center; }
.pricing-card-37fa0b--highlighted { border-color: var(--color-accent); border-width: 2px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1); position: relative; }
.pricing-card-37fa0b--highlighted::before { content: 'Popular'; position: absolute;
  top: -12px; left: 50%; transform: translateX(-50%);
  background: var(--color-accent); color: var(--color-accent-contrast);
  padding: 2px 16px; border-radius: 20px; font-size: 0.75rem; }
.pricing-name-37fa0b { font-size: 1.25rem; }
.pricing-price-37fa0b { font-size: 2rem; font-weight: 700; color: var(--color-primary-on-bg);
  margin: var(--spacing-md) 0; }
.pricing-features-37fa0b { text-align: left; margin-bottom: var(--spacing-lg); }
.pricing-features-37fa0b li { padding: var(--spacing-sm) 0;
  border-bottom: 1px solid var(--color-border); }
.pricing-features-37fa0b li:last-child { border-bottom: none; }


.about-story, .about-mission, .about-values { margin-bottom: var(--spacing-xl); }
.values-list li { padding: var(--spacing-sm) 0; position: relative;
  padding-left: 1.5rem; }
.values-list li::before { content: '\2713'; position: absolute; left: 0;
  color: var(--color-primary-on-bg); font-weight: 700; }
.about-cta { text-align: center; margin-top: var(--spacing-xl); }
.contact-layout { display: grid;
  grid-template-columns: 1fr 1fr; gap: var(--spacing-xl); }
.contact-info { padding: var(--spacing-lg); background: var(--color-surface);
  border-radius: var(--radius); }


.blog-grid-37fa0b { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); }
.blog-card-37fa0b { padding: var(--spacing-lg); border: 1px solid var(--color-border);
  border-radius: var(--radius); }
.blog-card-37fa0b__title a { color: var(--color-text); }
.blog-card-37fa0b__title a:hover { color: var(--color-primary-on-bg); }
.blog-card-37fa0b__date { font-size: 0.85rem; color: var(--color-muted); }
.blog-card-37fa0b__category { font-size: 0.75rem; background: var(--color-primary);
  color: var(--color-on-primary); padding: 2px 8px; border-radius: 4px; }
.blog-card-37fa0b__summary { margin: var(--spacing-sm) 0; }
.blog-card-37fa0b__link { font-weight: 600; }
.article-header { margin-bottom: var(--spacing-xl); }
.article-meta { display: flex; gap: var(--spacing-md); color: var(--color-muted);
  font-size: 0.9rem; margin-top: var(--spacing-sm); }
.article-body h2 { margin-top: var(--spacing-xl); }
.article-body p { line-height: 1.8; }
.article-body ul, .article-body ol { margin: var(--spacing-md) 0;
  padding-left: 1.5rem; list-style: disc; }
.article-body code { background: var(--color-surface); padding: 2px 6px;
  border-radius: 4px; font-size: 0.9em; }
.article-tags { display: flex; gap: var(--spacing-sm); flex-wrap: wrap;
  margin: var(--spacing-xl) 0; }
.tag { background: var(--color-surface); padding: 4px 12px;
  border-radius: 20px; font-size: 0.8rem; }
.article-nav { margin-top: var(--spacing-xl);
  padding-top: var(--spacing-lg); border-top: 1px solid var(--color-border); }


.tutorials-grid-37fa0b { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); }
.tutorial-card-37fa0b { padding: var(--spacing-lg);
  border: 1px solid var(--color-border); border-radius: var(--radius); }
.tutorial-card-37fa0b__meta { display: flex; gap: var(--spacing-md);
  margin: var(--spacing-sm) 0; }
.difficulty { font-size: 0.75rem; padding: 2px 8px; border-radius: 4px; }
.difficulty--beginner { background: #d4edda; color: #155724; }
.difficulty--intermediate { background: #fff3cd; color: #856404; }
.difficulty--advanced { background: #f8d7da; color: #721c24; }


.use-cases-grid-37fa0b { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); margin-top: var(--spacing-lg); }
.use-case-item-37fa0b { padding: var(--spacing-lg); background: var(--color-surface);
  border-radius: var(--radius); border-left: 3px solid var(--color-primary); }
.testimonials-grid-37fa0b { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); margin-top: var(--spacing-lg); }
.testimonial-card-37fa0b { padding: var(--spacing-lg); background: var(--color-surface);
  border-radius: var(--radius); }
.testimonial-card-37fa0b blockquote { font-style: italic;
  margin-bottom: var(--spacing-md); }
.testimonial-card-37fa0b figcaption { font-weight: 600; color: var(--color-primary-on-bg); }
.faq-list-37fa0b { margin-top: var(--spacing-lg); }
.faq-item-37fa0b { border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--spacing-md); margin-bottom: var(--spacing-sm); }
.faq-item-37fa0b summary { font-weight: 600; cursor: pointer; }
.faq-item-37fa0b p { margin-top: var(--spacing-sm); margin-bottom: 0; }
.newsletter-form, .contact-form { max-width: 480px;
  margin: var(--spacing-lg) auto 0; }
/* Home newsletter + contact: centered premium panels (were left-aligned and
   looked generic). */
.newsletter, .contact-home { text-align: center; }
.newsletter .page-intro, .contact-home .page-intro {
  margin-left: auto; margin-right: auto; }
.newsletter .newsletter-form {
  max-width: 620px; margin: var(--spacing-lg) auto 0;
  justify-content: center; align-items: center;
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--spacing-lg);
  box-shadow: 0 18px 44px -28px rgba(0,0,0,0.4); }
.contact-home .contact-form {
  max-width: 620px; margin: var(--spacing-lg) auto 0; text-align: left; }
/* Feature-flag visual hooks (spec.software_feature_flags) */
.ff-hover_effects .feature-card-37fa0b:hover, .ff-hover_effects .pricing-card-37fa0b:hover,
.ff-hover_effects .btn:hover { transform: translateY(-3px); }
.ff-microinteractions .btn:active { transform: scale(0.97); }


.btn { display: inline-block; padding: 0.6rem 1.5rem; border: none;
  border-radius: var(--radius-button, var(--radius)); font-weight: 600; cursor: pointer;
  text-align: center; transition: all var(--transition);
  text-decoration: none; font-size: 0.95rem; }
.btn-primary { background: var(--color-primary); color: var(--color-on-primary); }
.btn-primary:hover { background: var(--color-primary-dark); color: var(--color-on-primary); }
.btn-secondary { background: transparent; color: var(--color-primary-on-bg);
  border: 2px solid var(--color-primary-on-bg); }
.btn-secondary:hover { background: var(--color-primary-on-bg); color: var(--color-bg); }
.btn-accent { background: var(--color-accent); color: var(--color-accent-contrast); }
.btn-accent:hover { background: var(--color-accent-dark); color: var(--color-accent-contrast); }
.btn-lg { padding: 0.8rem 2rem; font-size: 1.1rem; }
/* On the primary-coloured header bar the page-bg-tuned outline button would be
   invisible, so header buttons use the on-primary text color instead. */
.site-header .btn-secondary { color: var(--color-on-primary);
  border-color: color-mix(in srgb, var(--color-on-primary) 55%, transparent); }
.site-header .btn-secondary:hover { background: var(--color-on-primary);
  color: var(--color-primary); border-color: var(--color-on-primary); }
/* Header call-to-action uses the accent so it stands out from the primary bar. */
.header-cta.btn-primary { background: var(--color-accent); color: var(--color-accent-contrast); }
.header-cta.btn-primary:hover { background: var(--color-accent-dark); }


/* --- Premium baseline shared by every generated form (.site-form) --- */
.form-group { margin-bottom: var(--spacing-md); position: relative; }
.form-group label { display: block; margin-bottom: 0.4rem; font-weight: 600;
  font-size: 0.85rem; letter-spacing: 0.01em; color: var(--color-text); }
.form-group input, .form-group select, .form-group textarea {
  width: 100%; padding: 0.78rem 0.95rem; border: 1.5px solid var(--color-border);
  border-radius: var(--radius); font-size: 0.95rem; font-family: var(--font-body);
  color: var(--color-text); background: var(--color-bg); line-height: 1.4;
  -webkit-appearance: none; appearance: none;
  transition: border-color var(--transition), box-shadow var(--transition),
    background var(--transition); }
.form-group input::placeholder, .form-group textarea::placeholder {
  color: var(--color-muted); opacity: 0.85; }
.form-group textarea { min-height: 130px; resize: vertical; }
.form-group select { cursor: pointer; padding-right: 2.4rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23999' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 0.95rem center; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline: none; border-color: var(--color-accent); background: var(--color-bg);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 22%, transparent); }
/* Standalone forms read as a refined, elevated card. */
.site-form { width: 100%; }
.contact-page .contact-form, .contact-home .contact-form {
  background: var(--color-surface, #fff); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--spacing-xl);
  box-shadow: 0 18px 48px -24px rgba(0,0,0,0.28); }
.site-form button[type=submit], .site-form .btn[type=submit] {
  margin-top: var(--spacing-sm); }
.site-form .btn-primary {
  box-shadow: 0 10px 26px -12px color-mix(in srgb, var(--color-primary) 70%, transparent); }
.site-form .btn-primary:hover { transform: translateY(-1px); }
.pw-toggle { position: absolute; right: 0.6rem; bottom: 0.55rem;
  background: none; border: none; color: var(--color-primary);
  font-size: 0.8rem; cursor: pointer; }
.char-counter { display: block; margin-top: 4px; font-size: 0.75rem;
  color: var(--color-muted); text-align: right; }
.form-group.is-invalid input, input.is-invalid, textarea.is-invalid {
  border-color: #d33; box-shadow: 0 0 0 3px rgba(221,51,51,0.12); }
/* Floating labels */
.form-group.floating label { position: absolute; left: 0.7rem; top: 0.7rem;
  background: var(--color-bg); padding: 0 0.25rem; pointer-events: none;
  transition: transform var(--transition), color var(--transition);
  transform-origin: left top; }
.form-group.floating input, .form-group.floating textarea { padding-top: 0.7rem; }
.form-group.floating.filled label,
.form-group.floating:focus-within label {
  transform: translateY(-1.1rem) scale(0.8); color: var(--color-primary); }

/* --- Form style variants (form_diversity) so forms aren't all identical --- */
/* boxed = default look (explicit token, no overrides needed) */
.form--underline .form-group input,
.form--underline .form-group select,
.form--underline .form-group textarea {
  border: none; border-bottom: 2px solid var(--color-border);
  border-radius: 0; padding-left: 0; padding-right: 0; background: transparent; }
.form--underline .form-group input:focus,
.form--underline .form-group select:focus,
.form--underline .form-group textarea:focus {
  box-shadow: none; border-bottom-color: var(--color-primary); }
.form--filled-soft .form-group input,
.form--filled-soft .form-group select,
.form--filled-soft .form-group textarea {
  border: 1.5px solid color-mix(in srgb, var(--color-text) 10%, transparent);
  background: color-mix(in srgb, var(--color-text) 6%, var(--color-bg)); }
.form--filled-soft .form-group input:focus,
.form--filled-soft .form-group select:focus,
.form--filled-soft .form-group textarea:focus {
  background: var(--color-bg); border-color: var(--color-accent); }
.form--outlined .form-group input,
.form--outlined .form-group select,
.form--outlined .form-group textarea {
  border: 2px solid var(--color-border); border-radius: var(--radius); }
.form--card-elevated { background: var(--color-surface, #fff);
  border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--spacing-lg); box-shadow: 0 6px 24px rgba(0,0,0,0.08); }

/* Newsletter inline layouts: email field + button on one row. */
.newsletter-form.form--inline-pill,
.newsletter-form.form--inline-attached {
  display: flex; align-items: flex-end; gap: var(--spacing-sm);
  flex-wrap: wrap; }
.newsletter-form.form--inline-pill .form-group,
.newsletter-form.form--inline-attached .form-group {
  flex: 1 1 220px; margin-bottom: 0; }
.newsletter-form.form--inline-pill .form-group label,
.newsletter-form.form--inline-attached .form-group label { display: none; }
.newsletter-form.form--inline-pill .form-group input { border-radius: 999px; }
.newsletter-form.form--inline-pill .btn { border-radius: 999px; }
.newsletter-form.form--inline-attached .form-group input {
  border-top-right-radius: 0; border-bottom-right-radius: 0; }
.newsletter-form.form--inline-attached .btn {
  border-top-left-radius: 0; border-bottom-left-radius: 0; }
.newsletter-form.form--stacked .form-group label { display: block; }


.policy-page .policy-section { margin-bottom: var(--spacing-lg); }
.policy-page .policy-section h2 { font-size: 1.35rem; }
.policy-page .policy-section p { white-space: pre-line; }
.auth-page { display: flex; justify-content: center; }
.auth-card { width: 100%; max-width: 420px; position: relative; overflow: hidden;
  background: var(--color-surface, #fff); border: 1px solid var(--color-border);
  border-radius: var(--radius-lg); padding: var(--spacing-xl);
  box-shadow: 0 24px 60px -28px rgba(0,0,0,0.32); }
.auth-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 4px; background: linear-gradient(90deg,
    var(--color-primary), var(--color-accent)); }
.auth-card h1 { font-size: 1.75rem; }
.auth-form .btn { width: 100%; margin-top: var(--spacing-sm); }
.auth-links { margin-top: var(--spacing-md); text-align: center; font-size: 0.9rem; }
.auth-links a { color: var(--color-primary-on-bg); }


.generic-page .generic-head { margin-bottom: var(--spacing-xl); }
.generic-section { margin-bottom: var(--spacing-xl); }
.generic-section__title { font-size: 1.5rem; margin-bottom: var(--spacing-sm); }
.generic-section__body { color: var(--color-muted);
  margin-bottom: var(--spacing-md); max-width: 760px; }
.generic-meta, .generic-tag { display: inline-block; font-size: 0.72rem;
  font-weight: 700; letter-spacing: 0.03em; text-transform: uppercase;
  padding: 0.15rem 0.55rem; border-radius: 999px;
  background: color-mix(in srgb, var(--color-accent) 16%, transparent);
  color: var(--color-primary-on-bg); }

/* Accordion (faq / help_center) */
.generic-accordion { display: flex; flex-direction: column;
  gap: var(--spacing-sm); }
.generic-accordion__item { border: 1px solid var(--color-border);
  border-radius: var(--radius-md); background: var(--color-surface, #fff);
  overflow: hidden; }
.generic-accordion__q { cursor: pointer; padding: var(--spacing-md);
  font-weight: 600; display: flex; gap: var(--spacing-sm); align-items: center;
  justify-content: space-between; }
.generic-accordion__q::-webkit-details-marker { display: none; }
.generic-accordion__a { padding: 0 var(--spacing-md) var(--spacing-md);
  color: var(--color-muted); }

/* Timeline (changelog / roadmap) */
.generic-timeline { list-style: none; margin: 0; padding: 0;
  position: relative; padding-left: var(--spacing-lg); }
.generic-timeline::before { content: ''; position: absolute; left: 6px; top: 4px;
  bottom: 4px; width: 2px;
  background: color-mix(in srgb, var(--color-accent) 35%, transparent); }
.generic-timeline__item { position: relative; padding: 0 0 var(--spacing-lg) 0; }
.generic-timeline__marker { position: absolute; left: calc(-1 * var(--spacing-lg) + 1px);
  top: 4px; width: 12px; height: 12px; border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--color-accent) 18%, transparent); }
.generic-timeline__head { display: flex; gap: var(--spacing-sm);
  align-items: center; flex-wrap: wrap; margin-bottom: 0.25rem; }
.generic-timeline__title { font-weight: 600; }
.generic-timeline__body p { color: var(--color-muted); }

/* Status (status page) */
.generic-status { list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--spacing-sm); }
.generic-status__row { display: flex; gap: var(--spacing-sm); align-items: center;
  flex-wrap: wrap; padding: var(--spacing-md);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-surface, #fff); }
.generic-status__name { font-weight: 600; }
.generic-status__note { color: var(--color-muted); font-size: 0.9rem; }
.generic-status__badge { margin-left: auto; font-size: 0.75rem; font-weight: 700;
  padding: 0.2rem 0.6rem; border-radius: 999px;
  background: color-mix(in srgb, #2e9e5b 18%, transparent); color: #2e9e5b; }

/* Cards (integrations / partners / press / reviews / case_studies / community) */
.generic-cards { display: flex; flex-wrap: wrap; gap: var(--spacing-lg);
  justify-content: center; }
.generic-card { flex: 1 1 260px; max-width: 360px;
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-surface, #fff); padding: var(--spacing-lg);
  box-shadow: 0 10px 30px -24px rgba(0,0,0,0.4); }
.generic-card__meta { display: inline-block; margin-bottom: var(--spacing-sm); }
.generic-card__title { font-size: 1.1rem; margin-bottom: var(--spacing-sm); }
.generic-card__desc { color: var(--color-muted); }

/* List (careers / comparison / fallback) */
.generic-list { list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--spacing-md); }
.generic-list__item { padding: var(--spacing-md);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-surface, #fff); }
.generic-list__head { display: flex; gap: var(--spacing-sm); align-items: center;
  flex-wrap: wrap; margin-bottom: 0.25rem; }
.generic-list__title { font-weight: 600; }
.generic-list__desc { color: var(--color-muted); }

.generic-cta { text-align: center; margin-top: var(--spacing-xl); }


/* ── Auth (login/register) structural variants ───────────────────── */
.auth-page--split { display: grid; gap: var(--spacing-xl);
  grid-template-columns: 1fr 1fr; align-items: center; max-width: 980px; }
.auth-page--split .auth-card { max-width: none; }
.auth-aside { background: linear-gradient(135deg,
    var(--color-primary), var(--color-accent));
  color: var(--color-on-primary); border-radius: var(--radius-lg);
  padding: var(--spacing-xl); align-self: stretch; display: flex;
  flex-direction: column; justify-content: center; }
.auth-aside__brand { font-family: var(--font-heading); font-size: 1.6rem;
  font-weight: 700; }
.auth-aside__tagline { margin-top: var(--spacing-sm);
  color: color-mix(in srgb, var(--color-on-primary) 85%, transparent); }
.auth-page--minimal .auth-card { border: none; box-shadow: none;
  padding: var(--spacing-md); }
.auth-page--minimal .auth-card::before { display: none; }
.auth-page--bordered-panel .auth-card { border-width: 2px;
  border-color: var(--color-primary-on-bg); box-shadow: none; }
.auth-page--bordered-panel .auth-card::before { display: none; }
.auth-social { display: flex; flex-direction: column; gap: var(--spacing-sm);
  margin-bottom: var(--spacing-md); }
.auth-social__btn { width: 100%; }
.auth-divider { display: flex; align-items: center; text-align: center;
  color: var(--color-muted); font-size: 0.85rem; margin: var(--spacing-md) 0; }
.auth-divider::before, .auth-divider::after { content: ''; flex: 1;
  height: 1px; background: var(--color-border); }
.auth-divider span { padding: 0 var(--spacing-sm); }
.auth-form__row { display: flex; justify-content: space-between;
  align-items: center; gap: var(--spacing-sm); margin-bottom: var(--spacing-sm);
  font-size: 0.9rem; }
.auth-remember { display: inline-flex; align-items: center; gap: 0.4rem;
  color: var(--color-muted); }
.auth-forgot { color: var(--color-primary-on-bg); }

/* ── About page structural variants ──────────────────────────────── */
.about-page--split .about-body { display: grid; gap: var(--spacing-xl);
  grid-template-columns: 1.3fr 1fr; align-items: center; }
.about-figure img { width: 100%; border-radius: var(--radius-lg);
  box-shadow: 0 20px 50px -28px rgba(0,0,0,0.4); }
.about-page--centered { text-align: center; }
.about-page--centered .about-story, .about-page--centered .page-intro {
  max-width: 760px; margin-left: auto; margin-right: auto; }
.about-values-cards { display: flex; flex-wrap: wrap; gap: var(--spacing-md);
  justify-content: center; }
.about-value-card { flex: 1 1 200px; max-width: 280px; padding: var(--spacing-lg);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-surface, #fff); font-weight: 600; }
.about-values-timeline { list-style: none; margin: 0; padding-left: var(--spacing-lg);
  position: relative; }
.about-values-timeline::before { content: ''; position: absolute; left: 5px;
  top: 6px; bottom: 6px; width: 2px;
  background: color-mix(in srgb, var(--color-accent) 35%, transparent); }
.about-values-timeline__item { position: relative; padding: 0 0 var(--spacing-md) 0; }
.about-values-timeline__dot { position: absolute; left: calc(-1 * var(--spacing-lg) + 0px);
  top: 6px; width: 12px; height: 12px; border-radius: 50%;
  background: var(--color-accent); }

/* ── Features page structural variants ───────────────────────────── */
.features-rows { display: flex; flex-direction: column; gap: var(--spacing-xl);
  margin-top: var(--spacing-lg); }
.feature-row { display: grid; grid-template-columns: auto 1fr;
  gap: var(--spacing-lg); align-items: center; }
.feature-row--reverse { direction: rtl; }
.feature-row--reverse > * { direction: ltr; }
.feature-row__icon { display: inline-flex; align-items: center;
  justify-content: center; width: 64px; height: 64px; border-radius: 50%;
  font-size: 1.6rem; color: var(--color-on-primary);
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); }
.features-list { list-style: none; margin: var(--spacing-lg) 0 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--spacing-md);
  max-width: 760px; margin-left: auto; margin-right: auto; }
.features-list__item { display: flex; gap: var(--spacing-md);
  padding: var(--spacing-md); border: 1px solid var(--color-border);
  border-radius: var(--radius-md); background: var(--color-surface, #fff); }
.features-list__icon { font-size: 1.4rem; color: var(--color-primary-on-bg);
  margin-top: 0.2rem; }
.features-grid-37fa0b--two-col > * { flex-basis: 360px; }
@media (max-width: 720px) {
  .auth-page--split, .about-page--split .about-body { grid-template-columns: 1fr; }
  .feature-row { grid-template-columns: 1fr; }
  .feature-row--reverse { direction: ltr; }
}


.site-footer { background: var(--color-primary);
  color: color-mix(in srgb, var(--color-on-primary) 85%, transparent);
  padding: var(--spacing-xl) var(--spacing-lg); }
.footer-inner-37fa0b { max-width: var(--container-max); margin: 0 auto;
  display: grid; grid-template-columns: 1.5fr 3fr; gap: var(--spacing-xl);
  align-items: start; }
.footer-name { font-family: var(--font-heading); font-size: 1.25rem;
  font-weight: 700; color: var(--color-on-primary); }
.footer-tagline { font-size: 0.9rem; margin-top: var(--spacing-sm); }
.footer-cols { display: grid; gap: var(--spacing-lg);
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); }
.footer-col__title { color: var(--color-on-primary); font-size: 0.8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: var(--spacing-sm); }
.footer-col ul { display: flex; flex-direction: column; gap: var(--spacing-sm);
  list-style: none; padding: 0; margin: 0; }
.footer-col a { color: color-mix(in srgb, var(--color-on-primary) 70%, transparent); }
.footer-col a:hover { color: var(--color-on-primary); }
.footer-nav-37fa0b ul { display: flex; flex-direction: column; gap: var(--spacing-sm);
  list-style: none; padding: 0; margin: 0; }
.footer-nav-37fa0b a { color: color-mix(in srgb, var(--color-on-primary) 70%, transparent); }
.footer-nav-37fa0b a:hover { color: var(--color-on-primary); }
.footer-legal-37fa0b { grid-column: 1 / -1; font-size: 0.8rem; opacity: 0.7;
  padding-top: var(--spacing-md); border-top: 1px solid rgba(255,255,255,0.15);
  display: flex; justify-content: space-between; flex-wrap: wrap;
  gap: var(--spacing-sm); }
.footer-legal-37fa0b a { color: color-mix(in srgb, var(--color-on-primary) 70%, transparent); }
@media (max-width: 768px) {
  .footer-inner-37fa0b { grid-template-columns: 1fr; gap: var(--spacing-lg); }
  .footer-cols { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); }
}


.mobile-menu.hidden { display: none; }
.mobile-menu { position: fixed; inset: 0; z-index: 1000; }
.mobile-menu__backdrop { position: absolute; inset: 0;
  background: rgba(0,0,0,0.5); }
.mobile-menu__panel { position: absolute; right: 0; top: 0; bottom: 0;
  width: 280px; background: var(--color-bg); padding: var(--spacing-lg);
  overflow-y: auto; }
.mobile-menu__close { background: none; border: none; font-size: 1.5rem;
  cursor: pointer; margin-bottom: var(--spacing-lg); }
.mobile-menu__nav { display: flex; flex-direction: column; gap: var(--spacing-md); }
.mobile-menu__link { font-size: 1.1rem; color: var(--color-text); }


/* Header type variants */
.site-header--standard { position: static; }
.site-header--minimal { padding: var(--spacing-sm) var(--spacing-lg);
  background: var(--color-bg); color: var(--color-text);
  border-bottom: 1px solid var(--color-border); }
.site-header--minimal .site-name,
.site-header--minimal .main-nav .nav-link { color: var(--color-text); }
.site-header--minimal .main-nav .nav-link:hover { color: var(--color-primary); }
.site-header--sticky, .site-header--sticky_hidden { position: sticky; top: 0; }
.site-header--sticky_hidden { transition: transform 0.3s ease; }
.site-header--sticky_hidden.is-hidden { transform: translateY(-100%); }

/* Menu style variants */
.main-nav--horizontal-left { margin-right: auto; }
.main-nav--horizontal-center { margin: 0 auto; }
.main-nav--horizontal-right { margin-left: auto; }
.main-nav--floating-center .nav-list { justify-content: center; }

/* Footer style variants — all operate on the grouped .footer-cols grid. */
.site-footer--minimal .footer-inner-37fa0b { grid-template-columns: 1fr;
  text-align: center; gap: var(--spacing-md); }
.site-footer--minimal .footer-cols { grid-template-columns: 1fr; }
.site-footer--minimal .footer-col ul,
.site-footer--minimal .footer-nav-37fa0b ul { flex-direction: row;
  justify-content: center; flex-wrap: wrap; }
.site-footer--minimal .footer-col__title { display: none; }
.site-footer--centered .footer-inner-37fa0b { grid-template-columns: 1fr;
  text-align: center; justify-items: center; }
.site-footer--centered .footer-cols {
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  justify-items: center; }
.site-footer--widget-rich .footer-cols { grid-template-columns: repeat(4, 1fr); }
.site-footer--columns-4 .footer-cols { grid-template-columns: repeat(4, 1fr); }
.site-footer--columns-5 .footer-cols { grid-template-columns: repeat(5, 1fr); }
.site-footer--mega-menu .footer-inner-37fa0b { grid-template-columns: 1fr; }
.site-footer--mega-menu .footer-cols {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--spacing-xl); padding-top: var(--spacing-md); }
.site-footer--horizontal-bar .footer-inner-37fa0b { grid-template-columns: 1fr;
  text-align: center; gap: var(--spacing-md); }
.site-footer--horizontal-bar .footer-cols { display: flex; flex-wrap: wrap;
  justify-content: center; gap: var(--spacing-md) var(--spacing-lg); }
.site-footer--horizontal-bar .footer-col { display: flex; align-items: baseline;
  gap: var(--spacing-sm); }
.site-footer--horizontal-bar .footer-col__title { margin-bottom: 0;
  opacity: 0.6; }
.site-footer--horizontal-bar .footer-col ul { flex-direction: row;
  flex-wrap: wrap; gap: var(--spacing-md); }
@media (max-width: 768px) {
  .site-footer--widget-rich .footer-cols,
  .site-footer--columns-4 .footer-cols,
  .site-footer--columns-5 .footer-cols {
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); }
}

/* Header arrangement variants (design.layout.header_style) */
.site-header--style-centered .header-inner { justify-content: center;
  flex-direction: column; gap: var(--spacing-sm); text-align: center; }
.site-header--style-split .header-inner { justify-content: space-between; }
.site-header--style-minimal { padding: var(--spacing-sm) var(--spacing-lg); }
.site-header--style-hero_image { background: transparent; color: var(--color-text);
  position: absolute; left: 0; right: 0; box-shadow: none; }
/* An absolutely-positioned header overlaps the page flow, so the first section
   below it must reserve room or the hero content slides under the header. */
.site-header--style-hero_image ~ .site-main-wrap .site-content > .hero,
.site-header--style-hero_image ~ .site-main-wrap .site-content > .page-section-37fa0b:first-child {
  padding-top: calc(var(--spacing-xl) + 4.5rem); }

/* Nav placement (design.layout.nav_position). Brand + actions stay on the first
   row (so header_style space-between still works); the nav drops to its own full
   width row below them instead of wedging between and forcing a third row. */
.header-inner--nav-below_header { flex-wrap: wrap; }
.header-inner--nav-below_header .header-brand { order: 1; }
.header-inner--nav-below_header .header-actions { order: 2; }
.header-inner--nav-below_header .main-nav { order: 3; flex-basis: 100%;
  margin-top: var(--spacing-sm); }
.header-inner--nav-below_header .main-nav--horizontal-center .nav-list {
  justify-content: center; }
.header-inner--nav-below_header .main-nav--horizontal-right .nav-list {
  justify-content: flex-end; }

/* Pricing layout driven by tier count: 3 -> one row, 4 -> 2x2,
   5 -> 3 in the first row + 2 centered in the second. */
.pricing-grid-37fa0b--n3, .pricing-grid-37fa0b--n5 { display: flex; flex-wrap: wrap;
  justify-content: center; gap: var(--spacing-lg); }
.pricing-grid-37fa0b--n3 .pricing-card-37fa0b, .pricing-grid-37fa0b--n5 .pricing-card-37fa0b {
  flex: 1 1 calc(33.333% - var(--spacing-lg));
  max-width: calc(33.333% - var(--spacing-lg));
  padding: var(--spacing-lg) var(--spacing-md); }
.pricing-grid-37fa0b--n4 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 860px) {
  .pricing-grid-37fa0b--n3 .pricing-card-37fa0b, .pricing-grid-37fa0b--n5 .pricing-card-37fa0b {
    flex-basis: calc(50% - var(--spacing-lg));
    max-width: calc(50% - var(--spacing-lg)); }
}
@media (max-width: 560px) {
  .pricing-grid-37fa0b--n3 .pricing-card-37fa0b, .pricing-grid-37fa0b--n5 .pricing-card-37fa0b {
    flex-basis: 100%; max-width: 100%; }
  .pricing-grid-37fa0b--n4 { grid-template-columns: 1fr; }
}

/* Pricing block diversity */
.pricing-grid-37fa0b--cards-2col { grid-template-columns: repeat(2, 1fr); }
.pricing-grid-37fa0b--stacked-rows { grid-template-columns: 1fr; }
.pricing-grid-37fa0b--compact-list { grid-template-columns: 1fr; gap: var(--spacing-sm); }
.pricing-grid-37fa0b--compact-list .pricing-card-37fa0b { display: flex; align-items: center;
  justify-content: space-between; text-align: left; gap: var(--spacing-md); }
.pricing-grid-37fa0b--split-featured .pricing-card-37fa0b--highlighted { transform: scale(1.05); }
.pricing-card-37fa0b--flat { box-shadow: none; border: 1px solid var(--color-border); }
.pricing-card-37fa0b--shadow { box-shadow: 0 2px 10px rgba(0,0,0,0.08); border: none; }
.pricing-card-37fa0b--bordered { border: 2px solid var(--color-border); }
.pricing-card-37fa0b--gradient-header {
  background: linear-gradient(180deg, var(--color-surface), var(--color-bg)); }
.pricing-grid-37fa0b--hl-glow .pricing-card-37fa0b--highlighted {
  box-shadow: 0 0 24px rgba(0,0,0,0.18); }
.pricing-grid-37fa0b--hl-uniform .pricing-card-37fa0b--highlighted::before { content: none; }
.btn-pricing--outline { background: transparent; border: 2px solid var(--color-primary-on-bg);
  color: var(--color-primary-on-bg); }
.btn-pricing--ghost { background: transparent; color: var(--color-primary-on-bg); }
.btn-pricing--full-width { display: block; width: 100%; }

/* Download page diversity */
.download-page--hero-gradient h1 {
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent));
  -webkit-background-clip: text; background-clip: text; color: transparent; }
.download-grid-37fa0b--desktop-link, .download-grid-37fa0b--universal {
  grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
.btn-download--stacked-full { display: block; width: 100%; }
.btn-download--outline-text { background: transparent;
  border: 2px solid var(--color-primary-on-bg); color: var(--color-primary-on-bg); }
.download-extra { margin-top: var(--spacing-lg); text-align: center; }
.download-extra__note { font-size: 0.85rem; color: var(--color-muted); }

/* Back-to-top button (feature flag) */
.back-to-top { position: fixed; right: 1.5rem; bottom: 1.5rem; z-index: 200;
  width: 44px; height: 44px; border-radius: 50%; border: none;
  background: var(--color-primary); color: #fff; font-size: 1.25rem;
  cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,0.2);
  transition: transform var(--transition), background var(--transition); }
.back-to-top:hover { background: var(--color-primary-dark); }
.back-to-top--float-left { left: 1.5rem; right: auto; }
.back-to-top--float-right { right: 1.5rem; left: auto; }
.back-to-top[hidden] { display: none; }


/* Content layout (design_randomization.content_layout) */
.site-main-wrap { max-width: var(--container-max); margin: 0 auto;
  padding: 0 var(--spacing-lg); display: grid; gap: var(--spacing-xl);
  align-items: start; }
.site-main-wrap--single-column { display: block; padding: 0; }
.site-main-wrap--single-sidebar-left { grid-template-columns: 280px minmax(0, 1fr); }
.site-main-wrap--single-sidebar-right { grid-template-columns: minmax(0, 1fr) 280px; }
.site-main-wrap--double-sidebar {
  grid-template-columns: 240px minmax(0, 1fr) 240px; }
.site-main-wrap .site-content .page-section-37fa0b { padding-left: 0; padding-right: 0; }
.site-sidebar { position: sticky; top: 88px; display: flex;
  flex-direction: column; gap: var(--spacing-lg); }
.sidebar-widget { background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--spacing-lg); }
.sidebar-widget__title { font-size: 1rem; margin-bottom: var(--spacing-sm);
  color: var(--color-primary-on-bg); }
.sidebar-widget ul { display: flex; flex-direction: column; gap: 0.4rem; }
.sidebar-widget a { color: var(--color-text); font-size: 0.9rem; }
.sidebar-widget a:hover { color: var(--color-accent); }
.sidebar-widget--cta { background: var(--color-primary); color: var(--color-on-primary); }
.sidebar-widget--cta .sidebar-widget__title { color: var(--color-on-primary); }
.sidebar-widget--cta .btn { margin-top: var(--spacing-sm); }
.sidebar-widget p { font-size: 0.9rem; color: var(--color-muted);
  margin-bottom: var(--spacing-sm); }
.sidebar-search, .sidebar-newsletter, .sidebar-poll { display: flex;
  flex-direction: column; gap: var(--spacing-sm); }
.sidebar-search input, .sidebar-newsletter input { width: 100%;
  padding: 0.55rem 0.7rem; border: 1px solid var(--color-border);
  border-radius: var(--radius); background: var(--color-background);
  color: var(--color-text); font: inherit; }
.sidebar-search input:focus, .sidebar-newsletter input:focus {
  outline: none; border-color: var(--color-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 25%, transparent); }
.sidebar-poll label { display: flex; align-items: center; gap: 0.4rem;
  font-size: 0.9rem; color: var(--color-text); }
.sidebar-social { display: flex; flex-direction: row; flex-wrap: wrap;
  gap: 0.5rem; }
.sidebar-social a { padding: 0.3rem 0.6rem; border: 1px solid var(--color-border);
  border-radius: var(--radius); font-size: 0.85rem; }
/* Grid/masonry layouts: denser cards handled via flex-basis in the card-grid
   block below; nothing extra needed here for column templates. */
.layout-masonry .blog-grid-37fa0b { align-items: flex-start; }


/* Login / register links surfaced in navigation (auth_placement) */
.nav-link--auth { font-weight: 600; }
.nav-auth--icon .nav-link--auth { display: inline-flex; align-items: center;
  gap: 0.35rem; }
.auth-icon { display: inline-block; }
.header-auth { font-size: 0.85rem; padding: 0.4rem 1rem; }
.footer-auth a { font-weight: 600; }


/* Blog article blocks (content_blocks.article_blocks) */
.breadcrumbs { margin-bottom: var(--spacing-md); font-size: 0.85rem;
  color: var(--color-muted); }
.breadcrumbs__list { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.breadcrumbs__list li::after { content: '/'; margin-left: 0.4rem;
  color: var(--color-border); }
.breadcrumbs__list li:last-child::after { content: ''; }
.breadcrumbs a { color: var(--color-muted); }
.breadcrumbs a:hover { color: var(--color-accent); }
.article-thumbnail { height: 220px; border-radius: var(--radius-lg);
  margin-bottom: var(--spacing-lg); display: flex; align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); }
.article-thumbnail span { font-family: var(--font-heading); font-size: 4rem;
  font-weight: 700; color: #fff; opacity: 0.9; }
.article-author { display: flex; align-items: center; gap: 0.6rem;
  margin-top: var(--spacing-sm); }
.article-author__avatar { width: 36px; height: 36px; border-radius: 50%;
  background: var(--color-accent); color: var(--color-accent-contrast);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; }
.article-author__name { font-weight: 600; font-size: 0.9rem; }
.article-rating { display: flex; align-items: center; gap: 0.25rem;
  margin-top: var(--spacing-sm); }
.article-rating .star { color: var(--color-border); font-size: 1.1rem; }
.article-rating .star--on { color: var(--color-accent); }
.article-rating__value { font-size: 0.85rem; color: var(--color-muted);
  margin-left: 0.4rem; }
.article-pager { display: flex; justify-content: space-between;
  gap: var(--spacing-md); margin-top: var(--spacing-xl);
  border-top: 1px solid var(--color-border); padding-top: var(--spacing-lg); }
.article-pager a { color: var(--color-primary-on-bg); font-weight: 600;
  max-width: 45%; }
.article-pager__next { text-align: right; margin-left: auto; }
.related-news { margin-top: var(--spacing-xl); }
.related-news h2 { margin-bottom: var(--spacing-lg); }


/* Feature-flag visuals (spec.software_feature_flags) */
.scroll-progress { position: fixed; top: 0; left: 0; right: 0; height: 3px;
  background: transparent; z-index: 300; }
.scroll-progress__bar { display: block; height: 100%; width: 0;
  background: var(--color-accent); transition: width 0.1s linear; }
/* Dark-mode toggle: placement/style randomized per build (control_placements) */
.theme-toggle { z-index: 200; border: none; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 0.45rem; background: var(--color-primary); color: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
  transition: transform var(--transition), background var(--transition); }
.theme-toggle:hover { background: var(--color-primary-dark); }
.theme-toggle--float-left, .theme-toggle--float-right { position: fixed;
  bottom: 1.5rem; width: 44px; height: 44px; border-radius: 50%;
  font-size: 1.25rem; }
.theme-toggle--float-left { left: 1.5rem; }
.theme-toggle--float-right { right: 1.5rem; }
.theme-toggle--header { width: 38px; height: 38px; border-radius: 50%;
  font-size: 1.05rem; box-shadow: none;
  background: color-mix(in srgb, var(--color-on-primary) 12%, transparent);
  color: var(--color-on-primary); }
.theme-toggle--header:hover {
  background: color-mix(in srgb, var(--color-on-primary) 22%, transparent); }
.theme-toggle--footer { border-radius: var(--radius-button, var(--radius));
  padding: 0.5rem 1rem; font-size: 0.85rem; font-weight: 600;
  background: rgba(255,255,255,0.12); color: #fff; box-shadow: none; }
.theme-toggle--footer:hover { background: rgba(255,255,255,0.22); }
.theme-toggle__label { font-size: 0.85rem; }
.share-buttons { display: flex; gap: var(--spacing-sm);
  margin: var(--spacing-md) 0; }
.share-buttons__btn { font-size: 0.8rem; padding: 0.35rem 0.9rem;
  border: 1px solid var(--color-border); border-radius: 20px;
  color: var(--color-primary-on-bg); }
.share-buttons__btn:hover { background: var(--color-accent);
  color: var(--color-accent-contrast); border-color: var(--color-accent); }
.share-buttons--icons { gap: 0.5rem; align-items: center; }
.share-buttons--icons .share-buttons__btn { display: inline-flex;
  align-items: center; justify-content: center; width: 2.2rem; height: 2.2rem;
  padding: 0; border-radius: 50%; line-height: 1; }
.share-buttons--icons .share-buttons__icon { display: block; }
.share-buttons--inline { margin: 0; }
.article-meta-row, .article-rating-row { display: flex; align-items: center;
  gap: var(--spacing-md); flex-wrap: wrap; }
.article-meta-row--with-share.share-side--right,
.article-rating-row--with-share.share-side--right {
  justify-content: space-between; }
.article-rating-row { margin-top: var(--spacing-sm); }
.reading-time::before { content: '\23F1'; margin-right: 0.3rem; }
.code-highlight pre, .code-highlight code { background: #1e1e2e; color: #e0e0e0;
  border-radius: var(--radius); }
.code-highlight pre { padding: var(--spacing-md); overflow-x: auto; }
/* Mega menu: dropdown panels on top-level nav items */
.ff-megamenu .main-nav .nav-list > li { position: relative; }
.ff-megamenu .main-nav .has-megamenu .megamenu { display: none;
  position: absolute; top: 100%; left: 0; min-width: 240px;
  background: var(--color-bg); color: var(--color-text);
  box-shadow: 0 8px 24px rgba(0,0,0,0.15); padding: var(--spacing-md);
  border-radius: var(--radius); }
.ff-megamenu .main-nav .has-megamenu:hover .megamenu { display: block; }
/* Floating nav: header detaches into a floating pill */
.ff-floating_nav .site-header { background: transparent; box-shadow: none; }
.ff-floating_nav .header-inner { background: var(--color-primary);
  border-radius: 999px; padding: 0.5rem var(--spacing-lg);
  box-shadow: 0 6px 24px rgba(0,0,0,0.18); margin-top: var(--spacing-sm); }
/* A 999px radius only reads as a pill on a single-row header. Multi-row
   arrangements (nav below header, centered column) would balloon it into a tall
   blob, so fall back to a rounded card there. */
.ff-floating_nav .header-inner--nav-below_header,
.ff-floating_nav .site-header--style-centered .header-inner {
  border-radius: var(--radius-lg); }
/* Parallax-friendly hero */
.ff-parallax_scrolling .hero { background-attachment: fixed; }
/* Trust badges + notification dot hooks */
.ff-trust_badges .footer-brand-37fa0b::after { content: 'Secure • Verified';
  display: inline-block; margin-top: var(--spacing-sm); font-size: 0.75rem;
  padding: 2px 10px; border: 1px solid rgba(255,255,255,0.4);
  border-radius: 12px; }
.ff-notification_dot .header-cta { position: relative; }
.ff-notification_dot .header-cta::after { content: ''; position: absolute;
  top: -2px; right: -2px; width: 9px; height: 9px; border-radius: 50%;
  background: var(--color-accent); }


/* Table-of-contents placement variants (randomization.toc_placement) */
.article-layout { display: block; }
.article-layout--toc { display: grid; gap: var(--spacing-xl);
  align-items: start; }
.article-layout--toc-sidebar-left { grid-template-columns: 220px minmax(0, 1fr); }
.article-layout--toc-sidebar-right { grid-template-columns: minmax(0, 1fr) 220px; }
.article-toc { font-size: 0.85rem; }
.article-toc ul { display: flex; flex-direction: column; gap: 0.4rem; }
.article-toc a { color: var(--color-muted); }
.article-toc a:hover { color: var(--color-accent); }
.article-toc__title { font-weight: 700; font-size: 0.9rem;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--color-text); margin-bottom: var(--spacing-sm); }
.article-toc--sidebar { position: sticky; top: 88px;
  border-left: 2px solid var(--color-border); padding-left: var(--spacing-md); }
.article-toc--top, .article-toc--inline-card { margin-bottom: var(--spacing-lg); }
/* TOC hosted inside a full page sidebar (double_sidebar layout) */
.sidebar-widget--toc ul { margin-top: var(--spacing-sm); }
.article-toc--inline-card { background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius);
  padding: var(--spacing-md) var(--spacing-lg); }
.article-toc--top ul, .article-toc--inline-card ul {
  flex-direction: row; flex-wrap: wrap; gap: var(--spacing-sm) var(--spacing-lg); }
@media (max-width: 768px) {
  .article-layout--toc { display: block; }
  .article-toc--sidebar { position: static; border-left: none;
    padding-left: 0; margin-bottom: var(--spacing-lg); }
}


/* Real icon-font usage across the design (randomization.icon_lib) */
.feature-card-37fa0b__icon { display: inline-flex; align-items: center;
  justify-content: center; width: 44px; height: 44px;
  border-radius: var(--radius); margin-bottom: var(--spacing-sm);
  background: color-mix(in srgb, var(--color-accent) 14%, transparent);
  color: var(--color-accent); font-size: 1.4rem; }
.benefit-item-37fa0b { display: flex; align-items: flex-start; gap: 0.6rem; }
.benefit-item-37fa0b__icon { color: var(--color-accent); font-size: 1.2rem;
  line-height: 1.4; flex-shrink: 0; }
.pricing-features-37fa0b li { display: flex; align-items: baseline; gap: 0.5rem; }
.pricing-features-37fa0b__icon { color: var(--color-accent); font-size: 0.85rem;
  flex-shrink: 0; }


/* Generated imagery: blog thumbnails + product screenshots */
.article-thumbnail img, .blog-card-37fa0b__media img { width: 100%; height: 100%;
  object-fit: cover; }
.blog-card-37fa0b__media { display: block; height: 180px; overflow: hidden;
  border-radius: var(--radius); margin-bottom: var(--spacing-sm);
  background: linear-gradient(135deg, var(--color-primary), var(--color-accent)); }
.product-showcase { max-width: var(--container-max); margin: 0 auto;
  padding: var(--spacing-xl) var(--spacing-lg); }
.product-showcase h2 { margin-bottom: var(--spacing-lg); }
.screenshot-grid { display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--spacing-lg); }
.screenshot-figure { margin: 0; border-radius: var(--radius-lg);
  overflow: hidden; border: 1px solid var(--color-border);
  box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.screenshot-figure img { width: 100%; display: block; }
.screenshot-figure figcaption { font-size: 0.85rem; color: var(--color-muted);
  padding: var(--spacing-sm) var(--spacing-md); }
.download-screenshot, .features-screenshot { margin: 0 auto var(--spacing-xl);
  max-width: 760px; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--color-border); box-shadow: 0 6px 20px rgba(0,0,0,0.1); }
.download-screenshot img, .features-screenshot img { width: 100%; display: block; }


/* Card collections wrap as centered flex rows so a partial final row is centered
   instead of leaving a visual hole on the right (CSS grid leaves orphan tracks
   empty). Cards grow to fill complete rows but are capped so a lone trailing
   card stays card-sized and simply centers rather than stretching full width. */
.benefits-grid-37fa0b > * { flex: 1 1 220px; max-width: 360px; }
.use-cases-grid-37fa0b > * { flex: 1 1 240px; max-width: 380px; }
.features-grid-37fa0b > *, .testimonials-grid-37fa0b > *, .screenshot-grid > * {
  flex: 1 1 280px; max-width: 440px; }
.blog-grid-37fa0b > *, .tutorials-grid-37fa0b > * { flex: 1 1 300px; max-width: 460px; }
.layout-grid-layout .features-grid-37fa0b > *,
.layout-masonry .features-grid-37fa0b > * { flex-basis: 240px; }


/* Dark mode (feature flag dark_mode_toggle) */
.theme-dark { --color-bg: #14151a; --color-surface: #1d1f27;
  --color-text: #e7e7ea; --color-muted: #9aa0ac; --color-border: #2c2f3a; }
.theme-dark body, body.theme-dark { background: var(--color-bg);
  color: var(--color-text); }
.theme-dark .feature-card-37fa0b, .theme-dark .pricing-card-37fa0b,
.theme-dark .download-card-37fa0b, .theme-dark .blog-card-37fa0b,
.theme-dark .sidebar-widget { background: var(--color-surface);
  border-color: var(--color-border); }
.theme-dark .auth-card { background: var(--color-surface); }


/* Sidebar layouts get cramped well before phone widths, so collapse the
   sidebar grids to a single column on tablets. */
@media (max-width: 980px) {
  .site-main-wrap--single-sidebar-left,
  .site-main-wrap--single-sidebar-right,
  .site-main-wrap--double-sidebar { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .main-nav { display: none; }
  .menu-toggle { display: block; }
  .header-cta { display: none; }
  .hero-headline { font-size: 2rem; }
  .hero-subtitle { font-size: 1rem; }
  .contact-layout { grid-template-columns: 1fr; }
  .footer-inner-37fa0b { grid-template-columns: 1fr; gap: var(--spacing-lg); }
  h1 { font-size: 1.75rem; }
  /* On mobile, sidebars always break the layout — hide them entirely and let
     the main content span the full width regardless of the chosen layout. */
  .site-sidebar { display: none; }
  .site-main-wrap { display: block; padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg); }
  /* Hero variants collapse to a single centred column on mobile. */
  .hero--split-left .hero-inner,
  .hero--split-right .hero-inner { grid-template-columns: 1fr; text-align: center; }
  .hero--split-left .hero-media,
  .hero--split-right .hero-media { order: 2; }
  .hero-actions { justify-content: center; }
}