:root{
  --bg:#F7FBF8;
  --surface:#ffffff;
  --card: rgba(255,255,255,0.78);
  --card2: rgba(255,255,255,0.92);
  --text:#0b1f14;
  --muted:#144b2f;
  --muted2:#2b5f44;
  --navy:#0b1f14;
  --accent:#006C35;   /* logo blue */
  --accent2:#0B8A44;  /* logo cyan */
  --accent3:#ffffff;  /* logo purple */
  --line: rgba(11,31,20,0.12);
  --ok:#0B8A44;
  --warn:#c9a227;
  --shadow: 0 12px 28px rgba(11,31,20,0.14);
  --radius: 18px;
  --radius2: 26px;
  --max: 1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background: var(--bg);}

a{color:inherit;text-decoration:none}
p{color:rgba(229,231,235,0.92);line-height:1.7}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.nav-wrap{position:sticky;top:0;z-index:50;background:rgba(6,9,21,0.72);backdrop-filter: blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:14px}
.brand{display:flex;align-items:center;gap:12px}
.logo{width:96px;height:96px;border-radius:18px;object-fit:contain;background:rgba(255,255,255,0.10);box-shadow:0 14px 34px rgba(11,31,20,0.16), inset 0 1px 0 rgba(255,255,255,0.35);}
.brand h1{font-size:1.12rem;margin:0;font-weight:850;letter-spacing:0.2px;color:var(--text)}
.brand .sub{font-size:0.9rem;color:var(--muted2);margin-top:2px;line-height:1.1;letter-spacing:0.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56vw}
.links{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:flex-end}
.links a{font-size:1rem;color:var(--text);padding:10px 12px;border-radius:14px;border:1px solid transparent;line-height:1}
.links a:hover{border-color:var(--line);background:rgba(255,255,255,0.04)}
.cta{display:flex;gap:10px;align-items:center}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:10px 14px;border-radius:14px;border:1px solid var(--line);
  background:rgba(255,255,255,0.04);
  color:var(--text);font-weight:650;font-size:0.95rem;
  transition:transform .18s ease, background .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.btn:hover{transform:translateY(-1px);background:rgba(255,255,255,0.07);border-color:rgba(25,88,161,0.35);box-shadow:0 16px 40px rgba(0,0,0,0.35)}
.btn.primary{
  border-color:rgba(25,88,161,0.35);
  background:linear-gradient(135deg, rgba(96,165,250,0.25), rgba(34,211,238,0.16));
}
.btn.primary:hover{border-color:rgba(34,211,238,0.45)}
.hero{padding:32px 0 20px}
.kicker{display:inline-flex;gap:10px;align-items:center;font-weight:700;font-size:0.92rem;color:rgba(203,213,225,0.95);
  padding:7px 12px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,0.04)}
.kicker .dot{width:8px;height:8px;border-radius:99px;background:var(--ok);box-shadow:0 0 0 6px rgba(52,211,153,0.12)}
.hero h2{font-size:3.05rem;line-height:1.02;margin:12px 0 12px;font-weight:900;letter-spacing:-0.8px}
.hero h2 .grad{background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:1.13rem;max-width:820px;margin:0 0 16px;color:rgba(229,231,235,0.92)}
.hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:18px;align-items:stretch;margin-top:18px}
@media(max-width:920px){.hero h2{font-size:2.3rem}.hero-grid{grid-template-columns:1fr}}
.panel{border:1px solid var(--line);background:rgba(255,255,255,0.03);border-radius:var(--radius2);padding:18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.panel:before{
  content:"";position:absolute;inset:-2px;
  background:radial-gradient(600px 240px at 20% 0%, rgba(96,165,250,0.18), rgba(0,0,0,0) 60%);
  pointer-events:none;
}
.panel-inner{position:relative}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}
@media(max-width:720px){.metrics{grid-template-columns:1fr}}
.metric{border:1px solid var(--line);background:rgba(255,255,255,0.04);border-radius:16px;padding:14px}
.metric .value{font-size:1.45rem;font-weight:900;letter-spacing:-0.4px}
.metric .label{color:rgba(203,213,225,0.86);font-size:0.9rem;margin-top:6px}
.section{padding:34px 0}
.section h3{font-size:1.9rem;margin:0 0 10px;font-weight:900;letter-spacing:-0.4px}
.section .lead{max-width:860px;margin:0 0 18px;color:rgba(229,231,235,0.9);font-size:1.06rem}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{
  grid-column: span 4;
  border:1px solid var(--line);background:rgba(255,255,255,0.04);
  border-radius:var(--radius);padding:18px;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.card:hover{transform:translateY(-3px);background:rgba(255,255,255,0.06);border-color:rgba(96,165,250,0.28)}
@media(max-width:980px){.card{grid-column: span 6}}
@media(max-width:640px){.card{grid-column: span 12}}
.card .icon{
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, rgba(25,88,161,0.35), rgba(34,211,238,0.22));
  border:1px solid rgba(255,255,255,0.12);
  margin-bottom:12px;
}
.card h4{margin:0 0 8px;font-size:1.15rem;font-weight:850}
.card p{margin:0;color:rgba(229,231,235,0.88);font-size:0.98rem}
.split{
  display:grid;grid-template-columns: 1fr 1fr;gap:18px;align-items:start;
}
@media(max-width:900px){.split{grid-template-columns:1fr}}
.bullet{border:1px solid var(--line);background:rgba(255,255,255,0.03);border-radius:18px;padding:18px}
.bullet h4{margin:0 0 8px;font-size:1.15rem;font-weight:850}
ul.clean{margin:10px 0 0;padding-left:18px;color:rgba(229,231,235,0.9)}
ul.clean li{margin:8px 0}
.quote{
  border:1px solid rgba(34,211,238,0.22);
  background:linear-gradient(135deg, rgba(34,211,238,0.10), rgba(96,165,250,0.07));
  border-radius:22px;padding:18px 18px 16px;margin-top:18px;
}
.quote .who{color:rgba(203,213,225,0.9);font-weight:700;margin-top:10px}
.footer{padding:22px 0;border-top:1px solid var(--line);background:rgba(6,9,21,0.5)}
.footer-grid{display:grid;grid-template-columns: 1.2fr 0.8fr;gap:18px;align-items:start}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr}}
.small{color:rgba(203,213,225,0.82);font-size:0.92rem;line-height:1.6}
.footer a{color:rgba(229,231,235,0.9)}
.footer a:hover{color:white;text-decoration:underline}
.badge{display:inline-flex;gap:8px;align-items:center;padding:7px 10px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,0.03);color:rgba(229,231,235,0.92);font-weight:650;font-size:0.88rem}
.badge .b{width:9px;height:9px;border-radius:99px;background:var(--accent2);box-shadow:0 0 0 6px rgba(34,211,238,0.10)}
.form{display:grid;gap:12px}
input, textarea{
  width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);
  background:rgba(255,255,255,0.04);color:var(--text);outline:none
}
textarea{min-height:120px;resize:vertical}
input:focus,textarea:focus{border-color:rgba(34,211,238,0.45);box-shadow:0 0 0 4px rgba(34,211,238,0.08)}
hr.soft{border:none;border-top:1px solid var(--line);margin:18px 0}
.mobile-toggle{display:none}
@media(max-width:860px){
  .mobile-toggle{display:inline-flex}
  .links{display:none;width:100%}
  .links.open{display:flex;flex-direction:column;align-items:flex-start;padding:12px 0}
}
.icon.icon3d,.icon3d{
  width:46px;height:46px;border-radius:16px;
  display:grid;place-items:center;
  background:
    radial-gradient(18px 18px at 30% 25%, rgba(255,255,255,0.35), rgba(255,255,255,0) 60%),
    linear-gradient(135deg, rgba(22,198,241,0.65), rgba(157,41,218,0.55));
  box-shadow:
    0 14px 28px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.22),
    inset 0 -8px 18px rgba(0,0,0,0.25);
  transform: translateZ(0);
}
.icon.icon3d{
  font-size:22px;
  filter: drop-shadow(0 6px 7px rgba(0,0,0,0.35));
}


/* GenAI-works-inspired layout blocks */
.hero--split{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:center}
@media (max-width: 900px){.hero--split{grid-template-columns:1fr}.hero__visual{order:-1}}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
@media (max-width: 900px){.metrics{grid-template-columns:repeat(2,1fr)}}
.metric{background:var(--card2);border:1px solid var(--line);border-radius:18px;padding:12px 14px;box-shadow:var(--shadow)}
.metric__num{font-weight:800;letter-spacing:.2px}
.metric__lbl{opacity:.85;font-size:.9rem}

.orb-stack{position:relative;min-height:360px;display:grid;place-items:center}
.orb{position:absolute;border-radius:999px;filter:blur(0px);opacity:.95}
.orb--a{width:280px;height:280px;background:radial-gradient(circle at 30% 30%, var(--accent2), transparent 60%);top:10px;left:10px}
.orb--b{width:240px;height:240px;background:radial-gradient(circle at 70% 30%, var(--accent3), transparent 60%);bottom:18px;right:6px}
.orb--c{width:220px;height:220px;background:radial-gradient(circle at 40% 70%, var(--accent), transparent 60%);bottom:40px;left:40px}

.card-3d{width:min(420px, 92%);background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.75));
  border:1px solid rgba(7,17,46,.12);border-radius:22px;box-shadow:var(--shadow);backdrop-filter: blur(10px);overflow:hidden}
.card-3d__top{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(7,17,46,.10)}
.card-3d__.card-3d__.card-3d__body{padding:14px 16px;display:flex;flex-wrap:wrap;gap:10px}
.card-3d__footer{padding:12px 16px;border-top:1px solid rgba(7,17,46,.10)}
.badge-3d{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;font-weight:900;
  background:linear-gradient(145deg, rgba(25,88,161,.95), rgba(22,198,241,.85));color:white;box-shadow:0 10px 18px rgba(7,17,46,.18)}
.pill{padding:8px 10px;border-radius:999px;border:1px solid rgba(7,17,46,.10);background:rgba(255,255,255,.65);font-size:.88rem}

.section__head{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:14px;flex-wrap:wrap}
.section__head .muted{max-width:680px}
.grid{display:grid;gap:14px}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media (max-width: 900px){.grid-3{grid-template-columns:1fr}}

.feature-card{display:block;background:var(--card);border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow);text-decoration:none;color:inherit}
.feature-card:hover{transform:translateY(-2px);transition:transform .15s ease}
.feature-card__title{font-weight:850;margin-top:10px}
.feature-card__text{opacity:.9;margin-top:6px}
.feature-card__cta{margin-top:12px;font-weight:750;color:var(--accent)}

.section--alt{background:rgba(255,255,255,.35);border-top:1px solid rgba(7,17,46,.10);border-bottom:1px solid rgba(7,17,46,.10)}
.audience{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width: 900px){.audience{grid-template-columns:1fr}}
.audience__col{background:rgba(255,255,255,.78);border:1px solid rgba(7,17,46,.10);border-radius:22px;padding:16px;box-shadow:var(--shadow)}
.audience__col h3{margin:0 0 6px 0}
.audience--secondary{margin-top:14px}

.section--cta{padding-top:0}
.cta-panel{display:flex;justify-content:space-between;gap:18px;align-items:center;background:linear-gradient(135deg, rgba(25,88,161,.16), rgba(22,198,241,.12), rgba(157,41,218,.12));
  border:1px solid rgba(7,17,46,.10);border-radius:26px;padding:18px;box-shadow:var(--shadow)}
@media (max-width: 900px){.cta-panel{flex-direction:column;align-items:stretch}}
.cta-panel__actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}


/* ===== GenAI-works-inspired top menu ===== */
.topbar{
  display:flex;
  align-items:center;
  gap:16px;
  padding:14px 0;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text);}
.brand .logo{width:96px;height:96px;border-radius:18px;object-fit:contain;background:rgba(255,255,255,0.10);box-shadow:0 14px 34px rgba(11,31,20,0.16), inset 0 1px 0 rgba(255,255,255,0.35);}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-weight:900;letter-spacing:-0.4px;font-size:1.05rem}
.brand-sub{font-size:.85rem;color:rgba(7,17,46,0.70);margin-top:3px;max-width:420px}

.nav-items{
  list-style:none;
  display:flex;
  align-items:center;
  gap:8px;
  margin:0;
  padding:0;
  margin-left:auto;
}
.nav-item{position:relative;}
.nav-link{
  appearance:none;
  border:0;
  background:transparent;
  color:rgba(7,17,46,0.82);
  font-weight:600;
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
}
.nav-link:hover, .nav-item.open > .nav-link{
  background:rgba(255,255,255,0.55);
  color: #2b6b62;
  box-shadow: 0 12px 30px rgba(7,17,46,0.12);
}
.nav-item.has-dropdown > .nav-link::after{
  content:"▾";
  font-size:12px;
  opacity:.75;
}

.dropdown{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:360px;
  background: rgba(255,255,255,0.92);
  border:1px solid rgba(7,17,46,0.10);
  border-radius:16px;
  padding:10px;
  box-shadow: 0 22px 60px rgba(7,17,46,0.22);
  backdrop-filter: blur(10px);
  display:none;
  z-index:50;
}
.nav-item.open > .dropdown{display:block;}

.drop-item{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 10px;
  border-radius:12px;
  text-decoration:none;
  color:var(--text);
}
.drop-item:hover{
  background: rgba(15,23,42,0.04);
}
.drop-text{display:flex;flex-direction:column;gap:2px}
.drop-title{font-weight:800}
.drop-sub{font-size:.88rem;color:rgba(7,17,46,0.60)}

.icon3d{
  position:relative;
  width:42px;height:42px;
  border-radius:12px;
  display:grid;place-items:center;
  font-weight:900;
  color: rgba(7,17,46,0.86);
  background: linear-gradient(135deg, var(--ig1,#60a5fa), var(--ig2,#1e40af));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.55),
    0 10px 20px rgba(7,17,46,0.18);
  transform: translateY(-0.5px);
}
.icon3d::after{
  content:"";
  position:absolute;
  width:42px;height:42px;
  border-radius:12px;
  box-shadow: inset 0 -8px 18px rgba(0,0,0,0.18);
  opacity:.55;
  pointer-events:none;
}

.topbar-cta{display:flex;align-items:center;gap:10px; margin-left:8px;}
.mobile-toggle{display:none;}

@media (max-width: 980px){
  .brand-sub{display:none;}
  .mobile-toggle{display:inline-flex;}
  .topbar{flex-wrap:wrap;}
  .nav-items{
    width:100%;
    display:none;
    flex-direction:column;
    align-items:stretch;
    margin-left:0;
    margin-top:10px;
    padding:10px;
    border-radius:16px;
    background: rgba(255,255,255,0.55);
    border:1px solid rgba(7,17,46,0.10);
  }
  .nav-items.open{display:flex;}
  .nav-link{width:100%;justify-content:space-between;}
  .dropdown{
    position:static;
    display:none;
    min-width:0;
    box-shadow:none;
    border-radius:14px;
    margin-top:8px;
    background: rgba(255,255,255,0.70);
  }
  .nav-item.open > .dropdown{display:block;}
}


/* GenAI.works-like nav theme (soft neutral + mint accent) */
:root{
  --nav-surface: rgba(255,255,255,0.72);
  --nav-surface-strong: rgba(255,255,255,.96);
  --nav-border: rgba(15, 23, 42, .10);
  --nav-text: var(--text);
  --nav-muted: var(--muted2);
  --nav-accent: var(--accent); /* mint */
  --nav-accent-2: var(--accent2);
  --nav-shadow: 0 18px 44px rgba(15,23,42,.14);
}


/* Top menu pills + dropdown panel */
.site-header{
  position: sticky;
  top: 0;
  z-index: 1000;
  backdrop-filter: blur(10px);
}
.navbar, .topnav, header .nav{
  background: var(--nav-surface);
  border: 1px solid var(--nav-border);
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
  border-radius: 18px;
}
.navbar a, .topnav a, header .nav a, .nav-links a{
  color: var(--nav-text) !important;
}
.navbar a:hover, .topnav a:hover, header .nav a:hover, .nav-links a:hover{
  color: rgba(15,23,42,.95) !important;
}

/* Pill-style top-level items */
.nav-item, .nav-links > a, .nav-links > button{
  border-radius: 999px !important;
}
.nav-item > a, .nav-item > button, .nav-links > a, .nav-links > button{
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: transparent;
}
.nav-item.is-open > a, .nav-item.is-open > button,
.nav-links > a.active, .nav-links > button.active{
  background: rgba(124, 201, 184, .25) !important;
  border: 1px solid rgba(124, 201, 184, .40) !important;
}

/* Dropdown container: like screenshot */
.dropdown, .nav-dropdown, .menu-dropdown{
  background: var(--nav-surface-strong) !important;
  border: 1px solid var(--nav-border) !important;
  border-radius: 18px !important;
  box-shadow: var(--nav-shadow) !important;
  padding: 10px !important;
  min-width: 360px;
}
.dropdown a, .nav-dropdown a, .menu-dropdown a{
  display:flex;
  gap: 12px;
  padding: 12px 12px;
  border-radius: 14px;
  text-decoration:none;
}
.dropdown a:hover, .nav-dropdown a:hover, .menu-dropdown a:hover{
  background: rgba(124,201,184,.18) !important;
}

/* Dropdown item layout (icon tile + text) */
.dd-item, .dropdown-item{
  display:flex;
  gap: 12px;
  align-items:flex-start;
}
.dd-icon, .dropdown-icon{
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: linear-gradient(145deg, rgba(124,201,184,.35), rgba(167,220,207,.25));
  border: 1px solid rgba(124,201,184,.30);
  box-shadow: 0 10px 18px rgba(15,23,42,.08);
  flex: 0 0 auto;
  position: relative;
  overflow:hidden;
}
.dd-icon::after, .dropdown-icon::after{
  content:"";
  position:absolute; inset:-20% -20% auto auto;
  width: 90px; height: 90px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), rgba(255,255,255,0) 60%);
  transform: rotate(18deg);
}
.dd-title, .dropdown-title{
  font-weight: 800;
  letter-spacing: .1px;
  color: rgba(15,23,42,.92);
  line-height: 1.1;
}
.dd-sub, .dropdown-subtitle{
  color: var(--nav-muted);
  font-size: .92rem;
  margin-top: 3px;
  line-height: 1.2;
}


/* KSA Flag Theme overrides */
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-color:transparent}
.btn-ghost{border-color:rgba(0,108,53,0.28);color:var(--text);background:rgba(255,255,255,0.35)}
.btn-ghost:hover{background:rgba(255,255,255,0.55)}
a.link, .link{color:var(--accent);text-decoration:none}
a.link:hover, .link:hover{text-decoration:underline}

.topnav, header, .nav{background:rgba(255,255,255,0.62);border-bottom:1px solid var(--line);backdrop-filter:blur(10px)}
.dropdown, .menu-panel, .nav-panel{background:rgba(255,255,255,0.92);border:1px solid var(--line)}
.kicker{color:var(--accent)}
.grad{background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;background-clip:text;color:transparent}


/* Ensure text inside cards/boxes is dark green */
.feature-card,
.audience__col,
.metric,
.card,
.card-3d,
.dropdown,
.menu-panel,
.nav-panel{
  color: var(--text);
}
.feature-card__text,
.muted{
  color: var(--muted2);
  opacity: 1;
}


/* Contrast fix: ensure supporting text is readable on light cards/background */
p, .lead, .feature-card__text, .metric__lbl, .tiny, .pill, .audience__col p, .card-3d__body, .card-3d__footer,
.section__head p, .cta-panel p, .dropdown .subtitle, .menu-item small{
  color: var(--muted) !important;
  opacity: 1 !important;
}

/* Some components used very light text; force them to inherit dark theme */
.hero p, .section p, .feature-card p, .audience__col p{
  color: var(--muted) !important;
  opacity: 1 !important;
}

/* If any 'muted' utility existed with low opacity, override */
.muted, .subtle, .hint{
  color: var(--muted2) !important;
  opacity: 1 !important;
}

/* Numbers remain strong, labels readable */
.metric__num, .feature-card__title, h1, h2, h3, h4{
  color: var(--text) !important;
}

/* Ensure card backgrounds aren't too close to page background */
.feature-card, .audience__col, .metric, .card-3d{
  background: rgba(255,255,255,0.90) !important;
}


/* Extra contrast fix: KPI tiles + quote footers */
.metric * ,
.metric__lbl,
.metric small,
.metric p,
.kpi, .kpi * ,
.stat, .stat * ,
.stats, .stats * ,
.tile, .tile * ,
.card small, .feature-card small, .audience__col small{
  color: var(--muted) !important;
  opacity: 1 !important;
}

.metric__num, .kpi strong, .stat strong, .stats strong{
  color: var(--text) !important;
  opacity: 1 !important;
}

/* Quote/attribution blocks */
blockquote, .quote, .quote * , .callout, .callout *{
  color: var(--text) !important;
  opacity: 1 !important;
}
blockquote footer, .quote .muted, .quote .subtitle, .callout .muted{
  color: var(--muted2) !important;
  opacity: 1 !important;
}

/* Prevent accidental low-contrast "disabled" style */
[style*="opacity"]{opacity: 1 !important;}


/* Comprehensive readability fix: lists + subtle text */
ul li, ol li, li,
ul li *, ol li *, li *{
  color: var(--muted) !important;
  opacity: 1 !important;
}

/* If a 'disabled' / 'soft' class is used for bullets, neutralize it */
.disabled, .is-disabled, .soft, .low, .faded, .dim, .light-text, .muted-light, .text-light{
  color: var(--muted2) !important;
  opacity: 1 !important;
}

/* Neutralize any per-element opacity used to fade content */
.hero li, .section li, .feature-card li, .audience__col li, .card li{
  opacity: 1 !important;
}

/* Ensure bullets are visible */
li::marker{
  color: rgba(11,31,20,0.45) !important;
}

/* Fix any generic "secondary text" class */
.subtitle, .subtext, .supporting, .secondary-text{
  color: var(--muted2) !important;
  opacity: 1 !important;
}


/* Nav typography normalization */
header, .topnav, .nav{
  font-size: 16px;
}
.nav a, .topnav a, header a, .nav .nav-link{
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: .2px;
}
.brand, .brand *{
  font-size: 18px !important;
  font-weight: 800 !important;
}
.brand .tagline{
  font-size: 13px !important;
  font-weight: 600 !important;
  opacity: .9;
}

/* Dropdown hover gap fix: keep menu open and clickable */
.nav-item{position:relative}
.nav-item .dropdown,
.nav-item .menu-panel{
  position:absolute;
  top: calc(100% + 10px);
  left: 0;
  min-width: 320px;
  z-index: 9999;
}

/* Create an invisible hover bridge so moving mouse doesn't close dropdown */
.nav-item::after{
  content:"";
  position:absolute;
  left:-10px;
  right:-10px;
  top:100%;
  height:14px;
}

/* Keep dropdown visible while hovering either trigger or dropdown */
.nav-item:hover .dropdown,
.nav-item:hover .menu-panel,
.nav-item:focus-within .dropdown,
.nav-item:focus-within .menu-panel{
  display:block;
  opacity:1;
  pointer-events:auto;
}

/* Ensure dropdown doesn't vanish due to pointer-events/opacity defaults */
.dropdown, .menu-panel{
  display:none;
  opacity:0;
  pointer-events:none;
  transform: translateY(6px);
  transition: opacity .15s ease, transform .15s ease;
}
.nav-item:hover .dropdown,
.nav-item:hover .menu-panel,
.nav-item:focus-within .dropdown,
.nav-item:focus-within .menu-panel{
  transform: translateY(0);
}

/* Make submenu items clearly clickable */
.dropdown a, .menu-panel a{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px 12px;
  border-radius:14px;
}
.dropdown a:hover, .menu-panel a:hover{
  background: rgba(0,108,53,0.06);
}


/* Open state for JS-controlled dropdowns */
.nav-item.open .dropdown,
.nav-item.open .menu-panel{
  display:block;
  opacity:1;
  pointer-events:auto;
  transform: translateY(0);
}

/* Nav dropdown readability + click targets */
.nav-item .nav-link{color:var(--text) !important;font-size:1rem}
.nav-item .nav-link .caret{opacity:.7}
.dropdown-panel a, .dropdown-panel button, .dropdown a{color:var(--text) !important}
.dropdown-panel .subtitle, .dropdown-panel small{color:var(--muted2) !important;opacity:1 !important}


/* Lighten top header to match page */
.site-header{backdrop-filter: blur(10px);}
.navbar, .topnav, header .nav, header, .topnav *{
  background: rgba(255,255,255,0.78) !important;
}
.navbar, .topnav, header .nav{
  border: 1px solid rgba(11,31,20,0.12) !important;
  box-shadow: 0 10px 22px rgba(11,31,20,0.10) !important;
}

.nav-wrap, .nav-inner, .nav-container{
  background: transparent !important;
}

.links a, .nav-item .nav-link, .brand h1, .brand .sub{font-size:0.9rem;color:var(--muted2);margin-top:2px;line-height:1.1;letter-spacing:0.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56vw}


/* Footer readability fix */
footer, .site-footer, .footer{
  background: rgba(255,255,255,0.78) !important;
  border-top: 1px solid var(--line) !important;
}
footer *, .site-footer *, .footer *{
  color: var(--text) !important;
  opacity: 1 !important;
}
footer a, .site-footer a, .footer a{
  color: var(--accent) !important;
}
footer a:hover, .site-footer a:hover, .footer a:hover{
  text-decoration: underline;
}


/* Prevent CTA/button text wrapping (e.g., "Get started") */
.btn, .btn-primary, .btn-ghost, button.btn, a.btn{
  white-space: nowrap !important;
}

/* Header sizing for larger logo */
.nav{padding:12px 0}
.brand{gap:14px}

/* Brand sizing tweaks */
.brand{align-items:center}
.brand h1{line-height:1}


/* Fix low-contrast pills/badges (e.g., Platform/Delivery/Impact tags) */
.pill, .badge, .tag, .chip, .label,
.kicker-pill, .section-pill, .role-pill{
  background: rgba(0,108,53,0.10) !important;
  border: 1px solid rgba(0,108,53,0.22) !important;
  color: var(--text) !important;
  opacity: 1 !important;
}

.pill *, .badge *, .tag *, .chip *, .label *{
  color: var(--text) !important;
  opacity: 1 !important;
}


/* Anchor offset for sticky header (e.g., contact.html#demo) */
[id]{
  scroll-margin-top: 120px;
}


/* Force tagline to match nav item size */
header .brand .sub{font-size:0.9rem;color:var(--muted2);margin-top:2px;line-height:1.1;letter-spacing:0.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56vw}

@media (max-width: 900px){
  .brand .sub{max-width:70vw;font-size:0.82rem}
}


/* Footer copyright one-line alignment */
footer .fineprint, .site-footer .fineprint, .footer .fineprint,
footer .copyright, .site-footer .copyright, .footer .copyright{
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  white-space: nowrap !important;
  flex-wrap: nowrap !important;
}

footer .fineprint *, .site-footer .fineprint *, .footer .fineprint *,
footer .copyright *, .site-footer .copyright *, .footer .copyright *{
  white-space: nowrap !important;
}

@media (max-width: 520px){
  footer .fineprint, .site-footer .fineprint, .footer .fineprint,
  footer .copyright, .site-footer .copyright, .footer .copyright{
    white-space: normal !important;
    flex-wrap: wrap !important;
    row-gap: 6px !important;
  }
}


/* About: mission-follow block (matches mission layout) */
.mission-follow{margin-top:18px;max-width:920px}
.mission-follow h2{margin:0 0 8px 0;font-size:2rem;letter-spacing:-0.02em}
.mission-follow p{margin:0;font-size:1.02rem;line-height:1.6}
@media (max-width: 720px){
  .mission-follow h2{font-size:1.6rem}
  .mission-follow p{font-size:1rem}
}


/* Fix: remove input-like boxes inside KPI/metric tiles */
.metric input, .metric textarea, .metric select,
.kpi input, .kpi textarea, .kpi select,
.stat input, .stat textarea, .stat select,
.stats input, .stats textarea, .stats select{
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  font: inherit !important;
  color: var(--muted) !important;
  width: auto !important;
  display: inline !important;
}

/* If those elements are readonly fields, prevent caret */
.metric input[readonly], .kpi input[readonly], .stat input[readonly], .stats input[readonly]{
  pointer-events: none !important;
}


/* Fix: .label was incorrectly styled like a badge; keep metric labels plain */
.metric .label{
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: var(--muted) !important;
  display:block;
}
.metric .value{color: var(--text) !important;}


/* Fix layout/padding for deliverable cards (e.g., "What you'll get") */
.cards, .card-grid, .grid.cards, .deliverables, .deliverables-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
@media (max-width: 980px){
  .cards, .card-grid, .grid.cards, .deliverables, .deliverables-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 620px){
  .cards, .card-grid, .grid.cards, .deliverables, .deliverables-grid{
    grid-template-columns: 1fr;
  }
}

/* Ensure card content has consistent padding and doesn't hug the border */
.feature-card, .card, .tile, .panel{
  padding: 22px !important;
}
.feature-card h3, .feature-card h4, .card h3, .card h4{
  margin-top: 0 !important;
  margin-bottom: 8px !important;
}
.feature-card p, .card p{
  margin: 0 !important;
  line-height: 1.55 !important;
}


/* Fix: ensure grid-3 actually renders as 3-column grid */
.grid-3{
  display:grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap:16px !important;
}
@media (max-width: 980px){
  .grid-3{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 620px){
  .grid-3{ grid-template-columns: 1fr !important; }
}

/* Fix: card-3d inner padding for readable layout */
.card-3d__body{
  padding:22px !important;
}
.card-3d__body h4{
  margin:0 0 8px 0 !important;
}
.card-3d__body p{
  margin:0 !important;
  line-height:1.55 !important;
}


/* Upgrade icon treatment to stronger 3D look */
.icon-3d, .icon, .card-icon, .feature-icon, .pill-icon, .menu-icon, .icon-badge{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(255,255,255,0.85), rgba(0,108,53,0.10));
  border: 1px solid rgba(0,108,53,0.18);
  box-shadow:
    0 14px 28px rgba(11,31,20,0.14),
    inset 0 1px 0 rgba(255,255,255,0.70),
    inset 0 -6px 14px rgba(0,108,53,0.08);
  transform: translateZ(0);
}

.icon-3d svg, .icon svg, .card-icon svg, .feature-icon svg, .pill-icon svg, .menu-icon svg, .icon-badge svg{
  width: 22px;
  height: 22px;
  filter: drop-shadow(0 2px 1px rgba(11,31,20,0.20));
}

.icon-3d img, .icon img, .card-icon img, .feature-icon img, .pill-icon img, .menu-icon img, .icon-badge img{
  width: 22px;
  height: 22px;
  filter: drop-shadow(0 2px 1px rgba(11,31,20,0.20));
}

/* Optional hover polish */
.feature-card:hover .icon-3d, .feature-card:hover .icon, .card-3d:hover .icon-3d, .card-3d:hover .icon{
  box-shadow:
    0 18px 34px rgba(11,31,20,0.16),
    inset 0 1px 0 rgba(255,255,255,0.75),
    inset 0 -8px 18px rgba(0,108,53,0.10);
  transform: translateY(-1px);
}

.menu-sep{height:1px;background: rgba(0,108,53,0.18);margin: 8px 0;}

/* Spacing tighten */
.section{ padding:40px 0; }
.section.hero{ padding:48px 0 44px; }
@media (max-width: 800px){
  .section{ padding:30px 0; }
  .section.hero{ padding: 48px 0 44px; }
}
.container{ max-width: 1120px; }

/* Layout tightening: reduce unused vertical whitespace */
.section{ padding: 40px 0; }
.section.hero{ padding: 48px 0 44px; }
.container{ max-width: 1120px; }
.grid-3{ gap: 18px !important; }
.card-3d{ border-radius: 18px; }
.card-3d__body{ padding: 20px !important; }
.lead{ font-size: 1.05rem; line-height: 1.65; max-width: 80ch; }


/* Extra tightening: reduce unused whitespace across pages */
:root{
  --section-pad: 34px;
  --section-pad-hero-top: 44px;
  --section-pad-hero-bottom: 34px;
  --card-pad: 18px;
  --grid-gap: 14px;
}

.section{ padding: var(--section-pad) 0 !important; }
.section.hero{ padding: var(--section-pad-hero-top) 0 var(--section-pad-hero-bottom) !important; }

.container{ max-width: 1100px !important; }

h1{ margin: 0 0 12px 0 !important; }
h2{ margin: 0 0 10px 0 !important; }
h3{ margin: 0 0 8px 0 !important; }
p{ margin: 0 0 12px 0 !important; }
ul{ margin: 10px 0 0 18px !important; }
li{ margin: 6px 0 !important; }

.grid-2, .grid-3, .grid-4{
  gap: var(--grid-gap) !important;
}

.card-3d__body, .card, .panel, .tile, .feature-card{
  padding: var(--card-pad) !important;
}

.callout{ padding: 16px !important; }

.btn-row{ margin-top: 14px !important; }
.btn{ padding: 10px 14px !important; }

.footer{ padding: 26px 0 !important; }
.footer-grid{ gap: 18px !important; }
.footer .muted{ margin-bottom: 0 !important; }

/* Reduce large top/bottom gaps inside hero blocks on some pages */
.hero .lead{ margin-top: 10px !important; }
.hero .btn-row{ margin-top: 12px !important; }

/* Reduce excess spacing between stacked cards/sections */
.stack > * + *{ margin-top: 12px !important; }


/* KPI band */
.kpi-band{padding:22px 0 10px;}
.kpi-head{display:flex;align-items:baseline;justify-content:space-between;gap:18px;margin:0 0 12px;}
.kpi-head h2{margin:0;font-size:18px;letter-spacing:-0.01em;}
.kpi-head p{margin:0;color:var(--muted2);font-size:13px;max-width:640px;}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;align-items:stretch;}
.kpi-card{background:var(--card2);border:1px solid var(--line);border-radius:16px;padding:12px 12px 10px;box-shadow:0 10px 22px rgba(11,31,20,0.06);backdrop-filter: blur(8px);}
.kpi-val{font-weight:900;font-size:22px;letter-spacing:-0.02em;color:var(--accent);}
.kpi-label{margin-top:4px;font-size:12.5px;color:var(--text);font-weight:600;text-transform:capitalize;}
.kpi-sub{margin-top:6px;font-size:12px;color:var(--muted2);}
.kpi-card-wide{grid-column:1 / -1;display:flex;flex-direction:column;}
@media (max-width: 980px){
  .kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .kpi-card-wide{grid-column:1 / -1;}
  .kpi-head{flex-direction:column;align-items:flex-start;}
}


/* Phase 1 components: Solutions comparison + CTAs */
.section-head{ display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.table-wrap{
  overflow:auto;
  border-radius: 16px;
  border: 1px solid rgba(11,108,53,0.16);
  background: rgba(255,255,255,0.70);
}
table.compare{ width: 100%; border-collapse: collapse; min-width: 760px; }
table.compare th, table.compare td{
  text-align:left; padding: 12px 12px;
  border-bottom: 1px solid rgba(11,108,53,0.12);
  vertical-align: top;
}
table.compare th{ font-size: 0.92rem; color: rgba(10,36,18,0.75); }
table.compare td{ font-size: 0.95rem; color: rgba(10,36,18,0.92); }

.cta-row{ display:flex; gap: 12px; flex-wrap:wrap; margin-top: 14px; }
.section.cta{ padding-top: 28px !important; padding-bottom: 28px !important; }
.cta-card{
  display:flex; gap: 16px; align-items:center; justify-content:space-between;
  border: 1px solid rgba(11,108,53,0.18);
  background: linear-gradient(135deg, rgba(255,255,255,0.75), rgba(11,108,53,0.08));
  border-radius: 18px;
  padding: 18px 18px;
}
@media (max-width: 860px){ .cta-card{ flex-direction:column; align-items:flex-start; } }
.cta-actions{ display:flex; gap: 12px; flex-wrap:wrap; }

/* Phase 2: Learning module layout */
.agenda{
  border: 1px solid rgba(11,108,53,0.16);
  background: rgba(255,255,255,0.60);
  border-radius: 16px;
  overflow:hidden;
}
.agenda__row{
  display:grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(11,108,53,0.10);
}
.agenda__row:last-child{ border-bottom: 0; }
.agenda__day{ font-weight: 800; color: #0b6c35; }
.agenda__topic{ color: rgba(10,36,18,0.92); }

/* Phase 2: Learning module structure */
.h3{ font-size: 1.05rem; margin: 0 0 10px 0; }
.tag-row{ display:flex; gap:8px; flex-wrap:wrap; margin-top: 10px; }
.tag{
  display:inline-flex; align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(11,108,53,0.16);
  background: rgba(255,255,255,0.55);
  font-size: 0.85rem;
  color: rgba(10,36,18,0.78);
}
.card-link{ text-decoration:none; color: inherit; }
.card-link:hover{ transform: translateY(-1px); }

ol.agenda{ margin: 10px 0 0 18px; }
ol.agenda li{ margin: 10px 0; }
ol.agenda li strong{ display:block; }

/* Improve program chips wrapping */
.chip-row{ display:flex; flex-wrap:wrap; gap:10px; margin-top:10px; }
.chip, .pill, .tagline-chip{
  display:inline-flex; align-items:center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(11,108,53,0.16);
  background: rgba(255,255,255,0.55);
}


/* Gov AI Literacy card emphasis */
.module-layout .grid-2{ gap: 16px !important; }
.module-layout .card-3d{ border-radius: 22px; }
.module-layout .card-3d__body{ padding: 22px 22px !important; }
.module-layout h3{
  font-size: 1.55rem !important;
  line-height: 1.1;
  margin: 0 0 10px 0 !important;
  letter-spacing: -0.2px;
}
.module-layout .bullets{ margin: 8px 0 0 22px !important; }
.module-layout .bullets li{
  margin: 8px 0 !important;
  font-size: 1.02rem !important;
  color: rgba(11,108,53,0.95) !important;
}
@media (max-width: 900px){
  .module-layout h3{ font-size: 1.35rem !important; }
  .module-layout .bullets li{ font-size: 0.98rem !important; }
}

/* Gov AI Literacy module cards (make text match reference layout) */
.gov-page .module-cards h3,
.module-cards h3{
  font-size: 1.6rem !important;
  line-height: 1.12 !important;
  margin: 0 0 10px 0 !important;
  letter-spacing: -0.2px !important;
}
.module-cards{ gap: 16px !important; }
.module-cards .card-3d{ border-radius: 22px !important; }
.module-cards .card-3d__body{ padding: 22px 22px !important; }
.module-cards .bullets{ margin: 8px 0 0 22px !important; }
.module-cards .bullets li{
  margin: 8px 0 !important;
  font-size: 1.02rem !important;
  color: rgba(11,108,53,0.95) !important;
}
@media (max-width: 900px){
  .module-cards h3{ font-size: 1.35rem !important; }
  .module-cards .bullets li{ font-size: 0.98rem !important; }
}

/* Global Learning module grid fix: keep the 2x2 cards side-by-side on desktop */
@media (min-width: 920px){
  .module-page .grid-2,
  .learning-page .grid-2,
  body[class*="module"] .grid-2,
  body.gov-page .grid-2{
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
    align-items: stretch !important;
  }
}
/* Ensure cards don't collapse due to width constraints */
.module-page .card-3d,
.learning-page .card-3d{ min-width: 0; }

/* Trust Center grid enforcement (keep cards side-by-side on desktop) */
@media (min-width: 920px){
  body.trust-page .grid-2{ display:grid !important; grid-template-columns: repeat(2, minmax(0,1fr)) !important; gap:16px !important; }
  body.trust-page .grid-3{ display:grid !important; grid-template-columns: repeat(3, minmax(0,1fr)) !important; gap:16px !important; }
}

/* Pillar buttons with icons */
.icon3d--sm{
  width: 30px !important;
  height: 30px !important;
  font-size: 16px !important;
  border-radius: 12px !important;
  flex: 0 0 30px !important;
}
.pill-text{ display:inline-flex; align-items:center; }
.pillar-buttons a,
.pillars a,
a.pill,
a.pillar-link{
  display:flex !important;
  align-items:center !important;
  gap: 10px !important;
}


/* Pillar left alignment (icon + label flush left) */
.pillar-buttons a,
.pillars a,
a.pill,
a.pillar-link{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap: 12px !important;
  padding-left: 14px !important;
}
.pillar-buttons a .pill-text,
.pillars a .pill-text,
a.pill .pill-text,
a.pillar-link .pill-text{
  flex: 1 1 auto;
  text-align: left !important;
}

/* Pillar button left-align (index) */
a.pillar-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap: 12px !important;
  padding-left: 14px !important;
  text-align: left !important;
}
a.pillar-btn .pill-text{ text-align:left !important; }

/* Pillar list alignment v3 (Four pillars block on Home) */
.pillar-list{ display:grid; gap:10px; margin-top:14px; }
.pillar-list .pillar-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap: 12px !important;
  text-align:left !important;
  padding-left: 16px !important;
}
.pillar-list .pillar-btn .pill-text{
  flex: 1 1 auto;
  text-align:left !important;
}

/* Title row inside cards (Trust Center / similar) */
.card-title-row{display:flex;gap:14px;align-items:flex-start}
.card-title-row .icon3d{flex:0 0 44px;width:44px;height:44px;border-radius:14px}
.card-title-row h4{margin:0}
.card-title-row + p{margin-top:8px}

/* Card row layout: icon on the left, text on the right */
.card-row{display:flex;gap:14px;align-items:flex-start}
.card-row .icon3d{flex:0 0 44px;width:44px;height:44px;border-radius:14px}
.card-row__content{flex:1;min-width:0}
.card-row__content h4{margin:0 0 6px 0}
.card-row__content p{margin:0;opacity:.92}


/* QA / Production quality components */
.kpi-band{margin-top:-18px;margin-bottom:18px}
.kpi-band .kpi-wrap{display:flex;flex-wrap:wrap;gap:12px;padding:14px;border-radius:18px;border:1px solid rgba(0,0,0,0.08);background:rgba(255,255,255,0.78);box-shadow:0 18px 40px rgba(0,0,0,0.06)}
.kpi{flex:1 1 150px;min-width:150px;padding:10px 12px;border-radius:14px;border:1px solid rgba(22,163,74,0.18);background:rgba(22,163,74,0.06)}
.kpi .kpi-val{font-weight:900;font-size:1.35rem;color:var(--accent)}
.kpi .kpi-lbl{margin-top:4px;font-size:0.85rem;color:rgba(10,42,23,0.85);font-weight:650}
.smallprint{font-size:0.82rem;color:rgba(10,42,23,0.7);line-height:1.45;margin-top:10px}

/* QA matrix table */
.qa-table{width:100%;border-collapse:separate;border-spacing:0 10px}
.qa-table th{font-size:0.85rem;text-align:left;color:rgba(10,42,23,0.75);padding:0 12px}
.qa-table td{padding:14px 12px;background:rgba(255,255,255,0.82);border:1px solid rgba(0,0,0,0.08)}
.qa-table tr td:first-child{border-radius:14px 0 0 14px}
.qa-table tr td:last-child{border-radius:0 14px 14px 0}
.qa-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;border:1px solid rgba(22,163,74,0.22);background:rgba(22,163,74,0.08);color:#0b6c35;font-weight:750;font-size:0.82rem;white-space:nowrap}
.qa-chip i{opacity:.9}

/* Release gates */
.gates{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media (max-width: 860px){.gates{grid-template-columns:1fr}}
.gate{padding:16px;border-radius:16px;border:1px solid rgba(0,0,0,0.08);background:rgba(255,255,255,0.82)}
.gate h4{margin:0 0 6px 0}
.gate p{margin:0;color:rgba(10,42,23,0.85);line-height:1.5}


.section-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:rgba(22,163,74,0.08);border:1px solid rgba(22,163,74,0.18);color:#0b6c35;font-weight:800;font-size:.82rem}



.process-flow{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-top:14px}
.process-step{background:rgba(255,255,255,0.86);border:1px solid rgba(0,0,0,0.08);border-radius:16px;padding:12px 14px}
.process-step .num{font-weight:900;color:var(--accent);font-size:.9rem}
.process-step .ttl{font-weight:900;margin-top:6px}
.process-step .desc{margin-top:6px;color:rgba(10,42,23,0.85);font-size:.9rem;line-height:1.35}
@media (max-width: 980px){.process-flow{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width: 640px){.process-flow{grid-template-columns:repeat(2,minmax(0,1fr))}}



.qa-gates{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:14px}
.gate{background:rgba(255,255,255,0.86);border:1px solid rgba(0,0,0,0.08);border-radius:16px;padding:14px 14px}
.gate h4{margin:0 0 8px 0}
.gate ul{margin:0;padding-left:18px;color:rgba(10,42,23,0.9);line-height:1.5}
@media (max-width: 980px){.qa-gates{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 640px){.qa-gates{grid-template-columns:1fr}}



/* Eyebrow pill */
.section-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:rgba(22,163,74,0.08);border:1px solid rgba(22,163,74,0.18);color:#0b6c35;font-weight:800;font-size:.82rem}

/* QA process flow */
.process-flow{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-top:14px}
.process-step{background:rgba(255,255,255,0.86);border:1px solid rgba(0,0,0,0.08);border-radius:16px;padding:12px 14px}
.process-step .num{font-weight:900;color:var(--accent);font-size:.9rem}
.process-step .ttl{font-weight:900;margin-top:6px}
.process-step .desc{margin-top:6px;color:rgba(10,42,23,0.85);font-size:.9rem;line-height:1.35}
@media (max-width: 980px){.process-flow{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width: 640px){.process-flow{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* QA gates grid */
.qa-gates{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-top:14px}
.gate{background:rgba(255,255,255,0.86);border:1px solid rgba(0,0,0,0.08);border-radius:16px;padding:14px 14px}
.gate h4{margin:0 0 8px 0}
.gate ul{margin:0;padding-left:18px;color:rgba(10,42,23,0.9);line-height:1.5}
@media (max-width: 980px){.qa-gates{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 640px){.qa-gates{grid-template-columns:1fr}}

/* AI news ticker */

.news-ticker-wrap{max-width:1100px;margin:18px auto 0;padding:0 16px;}
.news-ticker{background:rgba(255,255,255,.7);border:1px solid rgba(22,101,52,.18);border-radius:999px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.06);}
.news-ticker__item{flex:0 0 auto;white-space:nowrap;}

.news-ticker__label{display:none !important}
.news-ticker{position:relative;display:block;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,0.82);border:1px solid rgba(0,0,0,0.08);box-shadow:0 12px 30px rgba(0,0,0,0.06)}
.news-ticker__track{position:relative;overflow:hidden;width:100%}
.news-ticker__items{display:inline-flex;gap:22px;white-space:nowrap;will-change:transform;animation:marquee 28s linear infinite}
.news-ticker:hover .news-ticker__items{animation-play-state:paused}
.news-ticker__item{display:inline-flex;align-items:center;gap:10px;color:rgba(10,42,23,0.92);font-weight:700}
.news-ticker__item a{color:rgba(10,42,23,0.92);text-decoration:none;border-bottom:1px solid rgba(10,42,23,0.22)}
.news-ticker__item a:hover{border-bottom-color:rgba(10,42,23,0.55)}
.news-ticker__src{font-size:.86rem;color:rgba(10,42,23,0.62);font-weight:700}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ticker alias animation */
.news-ticker__items{width:max-content}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* =========================
   Important News (index)
   ========================= */
.important-news{margin-top:18px;margin-bottom:8px;}
.important-news__card{padding:18px 18px 16px;}
.important-news__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;}
.important-news__head h2{margin:0;font-size:18px;line-height:1.2;color:#052e16;font-weight:900;}
.important-news__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;}
.important-news__sub{margin:10px 0 12px;color:rgba(5,46,22,0.82);line-height:1.55;}
.important-news__stamp{font-size:12px;opacity:.8;white-space:nowrap;}
.important-news__body{display:grid;gap:10px;}
.important-news__summary{font-weight:700;color:#052e16;}
.important-news__bullets{margin:0;padding-left:18px;color:rgba(5,46,22,0.88);line-height:1.55;}
.important-news__links{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap;}
.important-news__link{font-size:12px;padding:8px 10px;border-radius:999px;border:1px solid rgba(15,23,42,0.12);background:rgba(255,255,255,0.85);text-decoration:none;color:#064e3b;}
.important-news__link:hover{text-decoration:underline;}
.skeleton-line{height:12px;border-radius:999px;background:rgba(2,6,23,0.06);overflow:hidden;position:relative;}
.skeleton-line:after{content:"";position:absolute;top:0;left:-40%;height:100%;width:40%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.55),transparent);animation:skeleton 1.2s infinite;}
@keyframes skeleton{0%{transform:translateX(0)}100%{transform:translateX(250%)}}

/* =========================
   Site Assistant (chatbot)
   ========================= */
.site-assistant{position:fixed;right:18px;bottom:18px;z-index:9999;font-family:inherit;}
.site-assistant__fab{display:flex;align-items:center;gap:10px;border:none;border-radius:999px;padding:12px 14px;background:linear-gradient(180deg,#16a34a,#15803d);color:white;box-shadow:0 16px 30px rgba(2,6,23,0.22);cursor:pointer;}
.site-assistant__fabIcon{font-size:16px;line-height:1;}
.site-assistant__fabText{font-weight:800;}
.site-assistant__panel{width:360px;max-width:calc(100vw - 24px);height:460px;max-height:calc(100vh - 110px);background:rgba(255,255,255,0.96);border:1px solid rgba(15,23,42,0.12);border-radius:18px;box-shadow:0 18px 50px rgba(2,6,23,0.20);display:none;overflow:hidden;}
.site-assistant__panel.is-open{display:flex;flex-direction:column;}
.site-assistant__header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px 12px 10px;border-bottom:1px solid rgba(15,23,42,0.08);}
.site-assistant__title{font-weight:900;color:#052e16;}
.site-assistant__subtitle{font-size:12px;opacity:.75;margin-top:2px;}
.site-assistant__close{border:none;background:transparent;cursor:pointer;font-size:18px;line-height:1;padding:6px 8px;border-radius:10px;}
.site-assistant__close:hover{background:rgba(2,6,23,0.06);}
.site-assistant__messages{padding:12px;display:flex;flex-direction:column;gap:10px;overflow:auto;flex:1;}
.assistant-msg{padding:10px 12px;border-radius:14px;line-height:1.45;font-size:13px;max-width:92%;}
.assistant-msg--bot{background:rgba(22,163,74,0.10);border:1px solid rgba(22,163,74,0.18);color:#052e16;}
.assistant-msg--user{align-self:flex-end;background:rgba(2,6,23,0.06);border:1px solid rgba(2,6,23,0.08);color:#0f172a;}
.assistant-result{margin-top:8px;display:grid;gap:8px;}
.assistant-hit{padding:10px;border-radius:14px;border:1px solid rgba(15,23,42,0.10);background:rgba(255,255,255,0.9);}
.assistant-hit a{color:#064e3b;font-weight:800;text-decoration:none;}
.assistant-hit a:hover{text-decoration:underline;}
.assistant-hit .snippet{margin-top:4px;font-size:12px;opacity:.8;}
.site-assistant__composer{display:flex;gap:10px;padding:12px;border-top:1px solid rgba(15,23,42,0.08);}
.site-assistant__input{flex:1;border-radius:999px;border:1px solid rgba(15,23,42,0.14);padding:10px 12px;outline:none;}
.site-assistant__input:focus{border-color:rgba(22,163,74,0.55);box-shadow:0 0 0 4px rgba(22,163,74,0.12);}
.site-assistant__send{border:none;border-radius:999px;padding:10px 14px;background:#0ea5e9;color:white;font-weight:800;cursor:pointer;}
.site-assistant__send:hover{filter:brightness(0.95);}
@media (max-width: 420px){.site-assistant__panel{width:calc(100vw - 24px);}}

/* Avoid overlap with footer on very short pages */
body{padding-bottom:72px;}


/* Metrics (cascading rows) */
.metrics-rows{
  margin-top: 18px;
  display: grid;
  gap: 12px;
}

.metric-row{
  display: grid;
  grid-template-columns: 132px 1fr;
  gap: 18px;
  align-items: center;
  padding: 16px 18px;
  border-radius: 16px;
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,.05);
  box-shadow: 0 10px 26px rgba(16,24,40,.08);
  transition: transform .15s ease, box-shadow .15s ease;
}

.metric-row:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 36px rgba(16,24,40,.12);
}

.metric-value{
  font-size: 44px;
  line-height: 1;
  font-weight: 850;
  letter-spacing: -0.02em;
  color: rgba(16,24,40,.95);
  white-space: nowrap;
}

.metric-text{
  display: flex;
  align-items: center;
}

.metric-label{
  font-size: 16px;
  line-height: 1.25;
  font-weight: 650;
  color: rgba(16,24,40,.78);
  max-width: 44ch;
}

@media (max-width: 520px){
  .metric-row{
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: start;
  }
  .metric-value{
    font-size: 40px;
  }
}
