:root {
  /* Official Luama AI palette — midnight / electric teal / violet glow */
  --ink: #0B1020;
  --paper: #ffffff;
  --soft: #F5F7FA;
  --muted: #6B7280;
  --line: #E2E6EE;
  --red: #7B61FF;    /* violet glow  (accent A) */
  --yellow: #00D4FF; /* electric teal (primary / CTA) */
  --orange: #5B77E8; /* teal→violet bridge */
  --blue: #00A8DE;   /* deep teal */
  --green: #22D3C4;  /* teal mint */
  --content: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "Plus Jakarta Sans", Inter, "Segoe UI", Arial, sans-serif; font-size: 16px; line-height: 1.5; letter-spacing: 0; }
body, button, input, textarea, select { font: inherit; letter-spacing: 0; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, textarea, select { border-radius: 0; }
button, a { -webkit-tap-highlight-color: transparent; }

.site-header { position: sticky; z-index: 30; top: 0; height: 72px; background: rgba(255,255,255,.97); border-bottom: 1px solid var(--line); }
.header-inner { width: min(calc(100% - 40px), var(--content)); height: 100%; margin: 0 auto; display: flex; align-items: center; gap: 30px; }
.brand { display: inline-flex; align-items: center; gap: 10px; min-width: 160px; }
.brand img { height: 46px; width: auto; }
.footer-brand .brand img { height: 40px; }
.brand span { display: grid; line-height: 1.05; }
.brand strong { font-size: .95rem; }
.brand small { margin-top: 4px; color: var(--muted); font-size: .66rem; text-transform: uppercase; }
.site-nav { display: flex; align-items: center; gap: 24px; margin-left: auto; }
.site-nav a, .text-link { font-size: .83rem; font-weight: 650; }
.site-nav a:hover, .text-link:hover { color: var(--blue); }
.header-actions { display: flex; align-items: center; gap: 18px; }
.menu-button { display: none; width: 42px; height: 42px; margin-left: auto; border: 1px solid var(--line); background: var(--paper); place-items: center; padding: 10px; }
.menu-button span { display: block; width: 18px; height: 2px; margin: 3px auto; background: var(--ink); }

.button { min-height: 46px; display: inline-flex; align-items: center; justify-content: center; padding: 0 20px; border: 1px solid transparent; font-size: .86rem; font-weight: 750; cursor: pointer; transition: transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease; }
.button:hover { transform: translateY(-2px); }
.button-small { min-height: 38px; padding: 0 15px; font-size: .79rem; }
.button-dark { background: var(--ink); color: var(--paper); }
.button-dark:hover { background: var(--blue); }
.button-yellow { background: var(--yellow); color: var(--ink); }
.button-yellow:hover { background: var(--paper); }
.button-outline-light { border-color: rgba(255,255,255,.48); color: var(--paper); background: transparent; }
.button-outline-light:hover { border-color: var(--paper); background: var(--paper); color: var(--ink); }
.button-outline-dark { border-color: var(--ink); color: var(--ink); background: transparent; }
.button-outline-dark:hover { background: var(--ink); color: var(--paper); }
.button-row { display: flex; flex-wrap: wrap; gap: 10px; }

.eyebrow { display: block; margin-bottom: 10px; color: var(--blue); font-size: .7rem; line-height: 1.2; font-weight: 800; text-transform: uppercase; }
.eyebrow.light { color: var(--yellow); }
.band { padding: 88px max(24px, calc((100vw - var(--content)) / 2)); }
.band-soft { background: var(--soft); }
.section-heading { display: grid; grid-template-columns: minmax(0, 1.45fr) minmax(260px, .75fr); gap: 60px; align-items: end; margin-bottom: 44px; }
.section-heading h2 { max-width: 760px; margin: 0; font-size: 2.25rem; line-height: 1.08; }
.section-heading p { margin: 0; color: var(--muted); font-size: .95rem; }

.home-hero { min-height: calc(100vh - 72px); padding: 0 24px 46px; overflow: hidden; background: var(--ink); color: var(--paper); }
.hero-color-rail, .footer-color-rail { display: grid; grid-template-columns: repeat(5, 1fr); width: min(100%, var(--content)); height: 6px; margin: 0 auto; }
.hero-color-rail i:nth-child(1), .footer-color-rail i:nth-child(1) { background: var(--red); }
.hero-color-rail i:nth-child(2), .footer-color-rail i:nth-child(2) { background: var(--yellow); }
.hero-color-rail i:nth-child(3), .footer-color-rail i:nth-child(3) { background: var(--orange); }
.hero-color-rail i:nth-child(4), .footer-color-rail i:nth-child(4) { background: var(--blue); }
.hero-color-rail i:nth-child(5), .footer-color-rail i:nth-child(5) { background: var(--green); }
.home-hero-inner { width: min(100%, var(--content)); margin: 0 auto; padding-top: 54px; }
.hero-copy { max-width: 880px; }
.hero-copy h1 { margin: 0; font-size: 5.4rem; line-height: .95; font-weight: 850; }
.hero-line { max-width: 900px; margin: 20px 0 0; font-size: 2.15rem; line-height: 1.12; font-weight: 650; }
.hero-summary { max-width: 720px; margin: 20px 0 28px; color: #bfc4bf; font-size: 1rem; }
.hero-access { display: flex; align-items: center; gap: 10px; margin-top: 17px; color: #aeb3ae; font-size: .78rem; }
.hero-access a { color: var(--yellow); font-weight: 750; }

.product-preview { display: grid; grid-template-columns: 190px 1fr; min-height: 370px; margin-top: 44px; overflow: hidden; border: 1px solid #393d39; border-radius: 8px; background: #f8f9f7; color: var(--ink); box-shadow: 0 24px 70px rgba(0,0,0,.32); }
.preview-sidebar { display: flex; flex-direction: column; padding: 20px 16px; background: #101110; color: var(--paper); }
.preview-logo { display: flex; align-items: center; gap: 9px; font-size: .72rem; font-weight: 750; }
.preview-logo img { width: 27px; height: 27px; border-radius: 4px; }
.preview-tenant { display: grid; margin: 28px 0 18px; padding: 12px; border: 1px solid #323532; border-radius: 4px; }
.preview-tenant small { color: #8f958f; font-size: .58rem; text-transform: uppercase; }
.preview-tenant strong { margin-top: 3px; font-size: .72rem; }
.preview-nav { display: grid; gap: 3px; }
.preview-nav span { padding: 8px 10px; color: #9da39d; border-radius: 4px; font-size: .68rem; }
.preview-nav .active { color: var(--ink); background: var(--yellow); font-weight: 800; }
.preview-owner { display: flex; align-items: center; gap: 8px; margin-top: auto; color: #a9afa9; font-size: .66rem; }
.preview-owner span { display: grid; width: 27px; height: 27px; place-items: center; border-radius: 50%; background: var(--blue); color: white; font-weight: 800; }
.preview-main { padding: 22px; }
.preview-toolbar { display: flex; justify-content: space-between; align-items: center; }
.preview-toolbar > div:first-child { display: grid; }
.preview-toolbar small { color: var(--muted); font-size: .61rem; }
.preview-toolbar strong { font-size: 1.15rem; }
.live-indicator { display: flex; align-items: center; gap: 6px; padding: 6px 9px; border: 1px solid var(--line); border-radius: 4px; color: var(--muted); font-size: .62rem; }
.live-indicator i { width: 7px; height: 7px; border-radius: 50%; background: var(--green); }
.preview-metrics { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 18px; }
.metric { position: relative; display: grid; min-height: 92px; padding: 13px; border: 1px solid var(--line); border-radius: 5px; background: var(--paper); overflow: hidden; }
.metric::before { position: absolute; content: ""; inset: 0 auto 0 0; width: 4px; background: var(--blue); }
.metric-yellow::before { background: var(--yellow); }.metric-orange::before { background: var(--orange); }.metric-green::before { background: var(--green); }
.metric small { color: var(--muted); font-size: .61rem; }.metric strong { font-size: 1.5rem; line-height: 1; }.metric span { color: var(--muted); font-size: .57rem; }
.preview-workspace { display: grid; grid-template-columns: 1.6fr .8fr; gap: 10px; margin-top: 10px; }
.work-stream, .health-panel { padding: 14px; border: 1px solid var(--line); border-radius: 5px; background: var(--paper); }
.panel-heading { display: flex; justify-content: space-between; padding-bottom: 10px; border-bottom: 1px solid var(--line); font-size: .65rem; }
.panel-heading span { color: var(--blue); }
.work-row { display: grid; grid-template-columns: 8px 1fr auto; gap: 9px; align-items: center; padding: 9px 0; border-bottom: 1px solid #eceeeb; }
.work-row:last-child { border-bottom: 0; }
.dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--orange); }.dot.blue { background: var(--blue); }.dot.yellow { background: var(--yellow); }.dot.green { background: var(--green); }
.work-row div { display: grid; }.work-row strong { font-size: .65rem; }.work-row small { color: var(--muted); font-size: .55rem; }.work-row b { color: var(--muted); font-size: .55rem; }
.health-score { display: grid; padding: 16px 0; }.health-score strong { font-size: .8rem; }.health-score span { color: #4d8f2a; font-size: .58rem; font-weight: 750; }
.health-item { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-top: 1px solid #eceeeb; font-size: .57rem; }.health-item span { display: flex; align-items: center; gap: 6px; }.health-item b { color: var(--muted); }

.automation-search { padding: 22px; border: 1px solid var(--line); border-radius: 6px; background: var(--paper); }
.automation-search label { display: block; margin-bottom: 8px; font-size: .72rem; font-weight: 750; }
.automation-search > div { display: grid; grid-template-columns: 1fr auto; }
.automation-search input { width: 100%; min-height: 54px; padding: 0 16px; border: 1px solid var(--ink); border-right: 0; outline: 0; }
.automation-search input:focus { box-shadow: inset 0 0 0 2px var(--blue); }
.automation-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.automation-tabs a { padding: 9px 12px; border: 1px solid var(--line); border-radius: 4px; font-size: .72rem; font-weight: 700; }
.automation-tabs a[aria-selected="true"] { border-color: var(--blue); background: var(--blue); color: var(--paper); }

.outcome-grid { display: grid; grid-template-columns: repeat(6, 1fr); border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.outcome-grid article { min-height: 150px; padding: 18px 14px; border-right: 1px solid var(--line); }
.outcome-grid article:last-child { border-right: 0; }
.outcome-grid span { display: block; color: var(--muted); font-size: .66rem; }.outcome-grid small { display: block; margin-top: 35px; color: var(--blue); font-size: .62rem; text-transform: uppercase; }.outcome-grid h3 { margin: 6px 0 0; font-size: .95rem; line-height: 1.2; }
.arrow-link { color: var(--blue); font-size: .8rem; font-weight: 750; }
.feature-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.feature { min-height: 220px; padding: 20px; border: 1px solid var(--line); border-radius: 6px; background: var(--paper); }
.feature > div { display: flex; justify-content: space-between; align-items: center; }
.feature-number { color: var(--muted); font-size: .66rem; }.feature i { width: 14px; height: 14px; border-radius: 50%; background: var(--blue); }
.feature-yellow i { background: var(--yellow); }.feature-orange i { background: var(--orange); }.feature-red i { background: var(--red); }.feature-green i { background: var(--green); }
.feature h3 { margin: 60px 0 10px; font-size: 1.12rem; }.feature p { margin: 0; color: var(--muted); font-size: .78rem; }

.ownership-band { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; padding: 88px max(24px, calc((100vw - var(--content)) / 2)); background: var(--ink); color: var(--paper); }
.ownership-band h2 { margin: 0; font-size: 2.8rem; line-height: 1.03; }.ownership-copy p { margin: 0 0 16px; color: #bdc2bd; }.ownership-copy .button-row { margin-top: 28px; }

.faq-list { border-top: 1px solid var(--ink); }
.faq-list details { border-bottom: 1px solid var(--line); }
.faq-list summary { display: flex; justify-content: space-between; gap: 20px; padding: 22px 0; cursor: pointer; list-style: none; font-weight: 750; }.faq-list summary::-webkit-details-marker { display: none; }.faq-list summary span { color: var(--blue); font-size: 1.4rem; line-height: 1; }.faq-list details[open] summary span { transform: rotate(45deg); }.faq-list p { max-width: 780px; margin: -5px 0 24px; color: var(--muted); }

.page-hero { position: relative; min-height: 480px; padding: 86px max(24px, calc((100vw - var(--content)) / 2)); overflow: hidden; background: var(--ink); color: var(--paper); }
.page-hero::after { position: absolute; content: ""; width: 260px; height: 8px; left: max(24px, calc((100vw - var(--content)) / 2)); bottom: 0; background: var(--red); box-shadow: 260px 0 0 var(--yellow), 520px 0 0 var(--orange), 780px 0 0 var(--blue), 1040px 0 0 var(--green); }
.page-hero-inner { position: relative; z-index: 2; max-width: 870px; }
.page-hero h1 { margin: 0; max-width: 900px; font-size: 3.9rem; line-height: 1; }
.page-hero p { max-width: 700px; margin: 24px 0 30px; color: #bec3be; font-size: 1.08rem; }
.page-hero-mark { position: absolute; right: max(24px, calc((100vw - var(--content)) / 2)); bottom: -34px; width: 190px; opacity: .14; }
.content-sections { display: grid; gap: 0; }
.content-section { display: grid; grid-template-columns: 90px 1fr; gap: 24px; padding: 34px 0; border-top: 1px solid var(--line); }
.content-section:last-child { border-bottom: 1px solid var(--line); }.content-section > span { color: var(--blue); font-size: .72rem; font-weight: 800; }.content-section h2 { margin: 0; font-size: 1.65rem; }.content-section p { max-width: 770px; margin: 9px 0 0; color: var(--muted); }
.doorway-band { display: grid; grid-template-columns: 150px 1fr auto; gap: 30px; align-items: center; padding: 48px max(24px, calc((100vw - var(--content)) / 2)); background: var(--yellow); }
.doorway-band .eyebrow { margin: 0; color: var(--ink); }.doorway-band h2 { margin: 0; font-size: 2rem; }.doorway-band p { margin: 4px 0 0; max-width: 660px; }

.account-layout { display: grid; grid-template-columns: .8fr 1.2fr; gap: 70px; align-items: start; }
.account-context h2 { margin: 0; font-size: 2.15rem; line-height: 1.1; }.account-context ol { margin: 34px 0; padding: 0; list-style: none; }.account-context li { display: grid; grid-template-columns: 38px 1fr; gap: 14px; padding: 17px 0; border-top: 1px solid var(--line); }.account-context li > span { display: grid; width: 30px; height: 30px; place-items: center; border-radius: 50%; background: var(--ink); color: var(--paper); font-size: .72rem; }.account-context li strong { font-size: .9rem; }.account-context li p { margin: 3px 0 0; color: var(--muted); font-size: .78rem; }
.security-note { padding: 18px; border-left: 5px solid var(--green); background: var(--soft); }.security-note strong { font-size: .9rem; }.security-note p { margin: 5px 0 0; color: var(--muted); font-size: .76rem; }
.account-form { padding: 28px; border: 1px solid var(--line); border-radius: 7px; background: var(--paper); box-shadow: 0 16px 50px rgba(20,30,20,.08); }
.form-heading span { color: var(--blue); font-size: .7rem; font-weight: 800; text-transform: uppercase; }.form-heading h2 { margin: 5px 0; font-size: 1.8rem; }.form-heading p { margin: 0; color: var(--muted); font-size: .78rem; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 17px; margin-top: 28px; }.form-grid label { display: grid; gap: 7px; }.form-grid label > span { font-size: .72rem; font-weight: 750; }.field-wide { grid-column: 1 / -1; }.form-grid input, .form-grid textarea, .form-grid select { width: 100%; padding: 12px 13px; border: 1px solid var(--line); background: #fbfcfa; outline: 0; font-size: .85rem; }.form-grid input:focus, .form-grid textarea:focus, .form-grid select:focus { border-color: var(--blue); box-shadow: 0 0 0 2px rgba(8,127,189,.12); }.form-grid textarea { resize: vertical; }
.checkbox-field { display: flex; align-items: flex-start; gap: 10px; margin: 20px 0; color: var(--muted); font-size: .72rem; }.checkbox-field input { width: 16px; height: 16px; margin: 2px 0 0; accent-color: var(--blue); }.checkbox-field a { color: var(--blue); text-decoration: underline; }.form-actions { display: flex; align-items: center; gap: 18px; }.form-actions a { color: var(--blue); font-size: .75rem; font-weight: 750; }.form-status { display: none; margin-top: 17px; padding: 14px; border-left: 5px solid var(--blue); background: #eaf6fb; font-size: .78rem; }.form-status.visible { display: block; }.form-status.success { border-color: var(--green); background: #edf8e8; }.form-status.error { border-color: var(--red); background: #fff0f2; }

.site-footer { background: var(--ink); color: var(--paper); }
.footer-color-rail { width: 100%; }
.footer-inner { width: min(calc(100% - 48px), var(--content)); margin: 0 auto; padding: 64px 0; display: grid; grid-template-columns: 1.7fr repeat(4, 1fr); gap: 42px; }
.footer-brand .brand small { color: #929792; }.footer-brand p { max-width: 300px; margin: 24px 0 12px; color: #aeb3ae; font-size: .78rem; }.footer-brand > strong { font-size: .72rem; }
.footer-column { display: grid; align-content: start; gap: 9px; }.footer-column h2 { margin: 0 0 7px; color: #8e948e; font-size: .67rem; text-transform: uppercase; }.footer-column a { color: #d8dcd8; font-size: .75rem; }.footer-column a:hover { color: var(--yellow); }
.footer-bottom { width: min(calc(100% - 48px), var(--content)); margin: 0 auto; padding: 20px 0 28px; border-top: 1px solid #303330; display: flex; justify-content: space-between; color: #8e948e; font-size: .68rem; }.footer-bottom span:last-child { display: flex; gap: 16px; }

@media (max-width: 980px) {
  .site-nav { position: fixed; inset: 72px 0 auto; display: none; padding: 22px; background: var(--paper); border-bottom: 1px solid var(--line); flex-direction: column; align-items: flex-start; }
  .site-nav.open { display: flex; }.menu-button { display: block; }.header-actions .text-link { display: none; }
  .hero-copy h1 { font-size: 4.2rem; }.hero-line { font-size: 1.75rem; }
  .product-preview { grid-template-columns: 145px 1fr; }.preview-sidebar { padding: 14px 10px; }.preview-main { padding: 16px; }.preview-metrics { grid-template-columns: repeat(2, 1fr); }.preview-workspace { grid-template-columns: 1fr; }.health-panel { display: none; }
  .outcome-grid { grid-template-columns: repeat(3, 1fr); }.outcome-grid article:nth-child(3) { border-right: 0; }.outcome-grid article:nth-child(-n+3) { border-bottom: 1px solid var(--line); }
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .ownership-band, .account-layout { grid-template-columns: 1fr; gap: 45px; }
  .doorway-band { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1.6fr repeat(2, 1fr); }.footer-brand { grid-row: span 2; }
}

@media (max-width: 680px) {
  .site-header { height: 64px; }.header-inner { width: min(calc(100% - 24px), var(--content)); gap: 10px; }.site-nav { top: 64px; }.brand { min-width: auto; }.brand img { width: 34px; height: 34px; }.brand small { display: none; }.header-actions .button { min-height: 36px; padding: 0 10px; font-size: .7rem; }.menu-button { width: 36px; height: 36px; }
  .band { padding: 64px 18px; }.section-heading { grid-template-columns: 1fr; gap: 15px; margin-bottom: 30px; }.section-heading h2 { font-size: 1.8rem; }
  .home-hero { min-height: auto; padding: 0 12px 30px; }.home-hero-inner { padding-top: 42px; }.hero-copy h1 { font-size: 3.3rem; }.hero-line { font-size: 1.45rem; }.hero-summary { font-size: .88rem; }
  .button-row { width: 100%; }.hero-copy .button-row .button, .page-hero .button-row .button { flex: 1; min-width: 145px; }
  .product-preview { display: block; min-height: 0; margin-top: 34px; }.preview-sidebar { display: none; }.preview-main { padding: 13px; }.preview-toolbar strong { font-size: .95rem; }.preview-metrics { gap: 6px; }.metric { min-height: 78px; padding: 10px; }.metric strong { font-size: 1.2rem; }.work-row { grid-template-columns: 8px 1fr; }.work-row > b { display: none; }
  .automation-search { padding: 15px; }.automation-search > div { grid-template-columns: 1fr; }.automation-search input { border-right: 1px solid var(--ink); }.automation-search .button { width: 100%; }
  .outcome-grid { grid-template-columns: repeat(2, 1fr); }.outcome-grid article:nth-child(3) { border-right: 1px solid var(--line); }.outcome-grid article:nth-child(even) { border-right: 0; }.outcome-grid article:nth-child(-n+4) { border-bottom: 1px solid var(--line); }
  .feature-grid { grid-template-columns: 1fr; }.feature { min-height: 170px; }.feature h3 { margin-top: 35px; }
  .ownership-band { padding: 64px 18px; }.ownership-band h2 { font-size: 2.1rem; }
  .page-hero { min-height: 430px; padding: 68px 18px; }.page-hero h1 { font-size: 2.55rem; }.page-hero p { font-size: .92rem; }.page-hero-mark { right: -30px; width: 150px; }
  .content-section { grid-template-columns: 45px 1fr; gap: 10px; }.content-section h2 { font-size: 1.35rem; }
  .doorway-band { padding: 42px 18px; }
  .account-form { padding: 19px; }.form-grid { grid-template-columns: 1fr; }.field-wide { grid-column: auto; }.form-actions { align-items: stretch; flex-direction: column; }.form-actions .button { width: 100%; }
  .footer-inner { grid-template-columns: 1fr 1fr; padding: 45px 0; }.footer-brand { grid-column: 1 / -1; grid-row: auto; }.footer-bottom { align-items: flex-start; flex-direction: column; gap: 10px; }
}

@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } * { transition: none !important; } }

/* ---------- flat design: zero border-radius everywhere ---------- */
*, *::before, *::after { border-radius: 0 !important; }
.dot, .live-indicator i { border-radius: 50% !important; } /* keep status lights legible */

/* ---------- showpiece: accountable flow + impact band (bold colour, flat discipline) ---------- */
.flow-section .flow { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(6, 1fr); border: 1px solid var(--line); }
.flow-step { padding: 24px 18px; border-right: 1px solid var(--line); background: var(--paper); }
.flow-step:last-child { border-right: 0; }
.flow-step > span { font-size: .72rem; font-weight: 850; color: var(--blue); letter-spacing: .04em; }
.flow-step strong { display: block; margin: 12px 0 7px; font-size: 1.02rem; line-height: 1.15; }
.flow-step small { color: var(--muted); font-size: .76rem; line-height: 1.4; }
.flow-human { background: var(--ink); color: var(--paper); }
.flow-human > span { color: var(--yellow); }
.flow-human small { color: #bfc4bf; }
.impact-band { background: var(--ink); color: var(--paper); padding: 0 0 68px; }
.impact-band .hero-color-rail { height: 6px; margin-bottom: 0; }
.impact-grid { width: min(100%, var(--content)); margin: 0 auto; padding: 58px 24px 0; display: grid; grid-template-columns: repeat(4, 1fr); border-left: 1px solid #2a2d2a; }
.stat { padding: 6px 28px; border-right: 1px solid #2a2d2a; }
.stat strong { display: block; font-size: 3.6rem; line-height: .95; font-weight: 850; }
.stat:nth-child(1) strong { color: var(--red); }
.stat:nth-child(2) strong { color: var(--yellow); }
.stat:nth-child(3) strong { color: var(--green); }
.stat:nth-child(4) strong { color: var(--orange); }
.stat small { display: block; margin-top: 14px; color: #bfc4bf; font-size: .85rem; line-height: 1.4; max-width: 22ch; }
@media (max-width: 900px) { .flow-section .flow { grid-template-columns: repeat(2, 1fr); } .flow-step { border-bottom: 1px solid var(--line); } .impact-grid { grid-template-columns: 1fr 1fr; } .stat { border-bottom: 1px solid #2a2d2a; padding-bottom: 22px; } }
@media (max-width: 600px) { .flow-section .flow { grid-template-columns: 1fr; } .impact-grid { grid-template-columns: 1fr; } .stat { border-right: 0; } }

/* ---------- Luama assistant chat widget (flat, on-brand) ---------- */
.luama-chat { position: fixed; right: 20px; bottom: 20px; z-index: 80; }
.chat-toggle { display: inline-flex; align-items: center; gap: 9px; background: var(--ink); color: var(--paper); border: 1px solid var(--ink); padding: 13px 18px; font-weight: 800; font-size: .85rem; cursor: pointer; box-shadow: 0 12px 30px rgba(0,0,0,.24); }
.chat-toggle:hover { background: var(--blue); border-color: var(--blue); }
.chat-dot { width: 9px; height: 9px; background: var(--green); border-radius: 50% !important; box-shadow: 0 0 0 3px rgba(121,201,75,.30); }
.chat-panel { position: absolute; right: 0; bottom: 60px; width: min(370px, calc(100vw - 40px)); height: min(540px, 72vh); display: flex; flex-direction: column; background: var(--paper); border: 1px solid var(--ink); box-shadow: 0 30px 80px rgba(0,0,0,.30); }
.chat-panel[hidden] { display: none; }
.chat-head { display: flex; align-items: center; gap: 10px; padding: 14px 16px; background: var(--ink); color: var(--paper); }
.chat-head img { width: 26px; height: 26px; }
.chat-head strong { display: block; font-size: .9rem; }
.chat-head small { font-size: .66rem; color: #bfc4bf; }
.chat-close { margin-left: auto; background: none; border: 0; color: var(--paper); font-size: 1.5rem; line-height: 1; cursor: pointer; }
.chat-log { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 10px; background: var(--soft); }
.chat-msg { max-width: 84%; padding: 10px 13px; font-size: .85rem; line-height: 1.42; border: 1px solid var(--line); background: var(--paper); }
.chat-msg.bot { align-self: flex-start; border-left: 3px solid var(--blue); }
.chat-msg.user { align-self: flex-end; background: var(--ink); color: var(--paper); border-color: var(--ink); }
.chat-quick { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 16px 8px; background: var(--soft); }
.chat-quick button { border: 1px solid var(--line); background: var(--paper); padding: 8px 11px; font-size: .76rem; font-weight: 700; cursor: pointer; }
.chat-quick button:hover { border-color: var(--blue); color: var(--blue); }
.chat-input { display: flex; border-top: 1px solid var(--line); }
.chat-input input { flex: 1; border: 0; padding: 14px; font: inherit; font-size: .85rem; }
.chat-input input:focus { outline: 2px solid var(--blue); outline-offset: -2px; }
.chat-input button { border: 0; background: var(--yellow); color: var(--ink); padding: 0 18px; font-size: 1.15rem; font-weight: 800; cursor: pointer; }
.chat-input button:hover { background: var(--ink); color: var(--paper); }
.chat-whatsapp { display: block; padding: 11px 16px; border-top: 1px solid var(--line); background: var(--ink); color: var(--paper); font-size: .78rem; font-weight: 800; text-align: center; }
.chat-whatsapp:hover { background: var(--blue); }
.inline-contact-link { color: var(--blue); font-weight: 850; text-decoration: underline; text-underline-offset: 3px; }
.section-note { display: block; margin-top: 7px; color: var(--muted); font-size: .72rem; }
@media (max-width: 600px) { .luama-chat { right: 12px; bottom: 12px; } }
.chat-typing { display: inline-flex; gap: 5px; align-items: center; min-width: 46px; }
.chat-typing span { width: 7px; height: 7px; background: var(--muted); border-radius: 50% !important; animation: luama-blink 1.2s infinite ease-in-out; }
.chat-typing span:nth-child(2) { animation-delay: .2s; }
.chat-typing span:nth-child(3) { animation-delay: .4s; }
@keyframes luama-blink { 0%, 80%, 100% { opacity: .25; } 40% { opacity: 1; } }
