:root{
  --bg:#000;
  --panel:#0c0e0d;
  --panel-2:#141716;
  --line:#232826;
  --text:#f2f4f3;
  --muted:#9aa3a0;
  --accent:#34d36b;
  --accent-dim:#1f7d45;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;   /* guard against horizontal overflow on narrow screens */
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.accent{color:var(--accent)}
.muted{color:var(--muted)}

/* nav */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(0,0,0,.78);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;letter-spacing:.04em}
.brand img{width:32px;height:32px;filter:invert(1)}
.brand small{display:block;font-weight:400;letter-spacing:.02em;font-size:11px;color:var(--muted)}
.nav-links{display:flex;gap:28px;align-items:center;font-size:14px;color:var(--muted)}
.nav-links a:hover{color:var(--text)}
.btn{
  display:inline-block;border:1px solid var(--accent);color:var(--accent);
  padding:9px 18px;border-radius:6px;font-size:14px;font-weight:600;
  transition:.18s;
}
.btn:hover{background:var(--accent);color:#021;}
.btn-solid{background:var(--accent);color:#021;border-color:var(--accent)}
.btn-solid:hover{background:#fff;border-color:#fff}
.nav-links a.btn{color:var(--accent)}
.nav-links a.btn:hover{color:#021}

/* hero */
.hero{
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.32}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.82) 70%,#000 100%)}
.hero-inner{position:relative;z-index:1;padding:118px 0 104px;max-width:820px}
.eyebrow{
  display:inline-block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--accent-dim);border-radius:40px;
  padding:6px 14px;margin-bottom:26px;
}
.hero h1{font-size:58px;line-height:1.05;font-weight:800;letter-spacing:-.02em}
.hero h1 .accent{display:block}
.hero p.lead{font-size:20px;color:var(--muted);margin:24px 0 36px;max-width:640px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats{display:flex;gap:46px;margin-top:58px;flex-wrap:wrap}
.hero-stats div span{display:block}
.hero-stats .n{font-size:30px;font-weight:800;color:var(--text)}
.hero-stats .l{font-size:13px;color:var(--muted);letter-spacing:.03em}

/* section */
section{padding:90px 0;border-bottom:1px solid var(--line)}
.sec-head{max-width:720px;margin-bottom:46px}
.sec-head .kicker{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:600}
.sec-head h1,.sec-head h2{font-size:38px;font-weight:800;letter-spacing:-.01em;margin:14px 0 12px}
.sec-head p{font-size:17px;color:var(--muted)}

/* capability grid */
.grid{display:grid;gap:18px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:24px;transition:.18s;
}
.card:hover{border-color:var(--accent-dim);background:var(--panel-2);transform:translateY(-3px)}
.card .ic{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;
  background:rgba(52,211,107,.12);color:var(--accent);font-size:18px;margin-bottom:16px;font-weight:700}
.card h3{font-size:17px;font-weight:700;margin-bottom:7px}
.card p{font-size:14px;color:var(--muted)}

/* product showcase rows */
.show{display:grid;grid-template-columns:1fr 1.25fr;gap:46px;align-items:center;margin-bottom:78px}
.show:last-child{margin-bottom:0}
.show.rev{grid-template-columns:1.25fr 1fr}
.show.rev .show-txt{order:2}
.show-txt h3{font-size:27px;font-weight:800;margin-bottom:6px}
.show-txt .sub{color:var(--accent);font-weight:600;margin-bottom:18px;font-size:15px}
.show-txt ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.show-txt li{position:relative;padding-left:24px;font-size:15px;color:#cdd3d1}
.show-txt li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;
  border-radius:2px;background:var(--accent)}
.show-txt .pp{display:inline-block;margin-left:10px;font-size:11px;color:var(--accent);
  border:1px solid var(--accent-dim);border-radius:20px;padding:2px 10px;letter-spacing:.04em;vertical-align:middle}

/* HTML image panels (rebuilt from embedded deck images) */
.show-media{width:100%}
.pgrid{display:grid;gap:6px;border-radius:14px;overflow:hidden;background:#000;
  box-shadow:0 22px 60px rgba(0,0,0,.55);border:1px solid var(--line)}
.pgrid.four{grid-template-columns:1fr 1fr}
.pgrid.two{grid-template-columns:1fr 1fr}
.pgrid.single{grid-template-columns:1fr}
.gcell{position:relative;margin:0;overflow:hidden;background:#0a0c0b;aspect-ratio:1/1}
.pgrid.two .gcell{aspect-ratio:3/4}
.pgrid.single .gcell{aspect-ratio:16/10}
.gcell img{width:100%;height:100%;object-fit:cover;display:block}
.cap{
  position:absolute;top:0;left:0;right:0;
  padding:12px 14px 26px;
  background:linear-gradient(180deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.45) 55%,rgba(0,0,0,0) 100%);
  pointer-events:none;
}
.cap b{display:block;font-size:13.5px;font-weight:700;color:#fff;letter-spacing:.01em;line-height:1.25}
.cap span{display:block;font-size:11.5px;color:#cfd6d3;margin-top:2px}
.cap.cap-right{left:auto;right:0;text-align:right;width:50%}
.cap.cap-left{width:50%}

/* solutions cards w/ image */
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sol{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;transition:.18s}
.sol:hover{border-color:var(--accent-dim);transform:translateY(-3px)}
.sol .thumb{aspect-ratio:16/10;overflow:hidden;border-bottom:1px solid var(--line)}
.sol .thumb img{width:100%;height:100%;object-fit:cover}
.sol .body{padding:18px 20px 22px}
.sol h3{font-size:17px;margin-bottom:6px}
.sol .body p{font-size:13.5px;color:var(--muted)}
.sol .pp{display:inline-block;margin-top:12px;font-size:11px;color:var(--accent);
  border:1px solid var(--accent-dim);border-radius:20px;padding:2px 9px;letter-spacing:.04em}

/* cta band */
.cta{background:linear-gradient(120deg,#06140c,#000);text-align:center}
.cta h2{font-size:40px;font-weight:800;letter-spacing:-.01em;margin-bottom:14px}
.cta p{color:var(--muted);font-size:18px;margin-bottom:30px}
.cta .hero-cta{justify-content:center}

/* footer */
footer{padding:54px 0 40px;border-bottom:none}
.foot{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot .brand small{max-width:260px}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap}
.foot-cols h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.foot-cols a{display:block;font-size:14px;color:#cdd3d1;margin-bottom:9px}
.foot-cols a:hover{color:var(--accent)}
.copy{margin-top:44px;padding-top:22px;border-top:1px solid var(--line);
  font-size:13px;color:var(--muted);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* mobile menu toggle (hidden on desktop) */
.nav-toggle{display:none;background:none;border:0;color:var(--text);font-size:24px;line-height:1;cursor:pointer;padding:6px 8px}

@media(max-width:900px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3,.sol-grid{grid-template-columns:repeat(2,1fr)}
  .show,.show.rev{grid-template-columns:1fr;gap:24px}
  .show.rev .show-txt{order:0}
  .hero h1{font-size:42px}
  .nav-toggle{display:inline-block;flex-shrink:0}
  header .brand small{display:none}   /* free width for the menu button */
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;
    background:rgba(0,0,0,.97);border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:0;padding:8px 0}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 24px}
  .nav-links a.btn{margin:8px 24px;text-align:center}
}
@media(max-width:560px){
  .grid-4,.grid-3,.grid-2,.sol-grid{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .hero-stats{gap:28px}
}

/* ---------- multi-page restructure ---------- */
.nav-links a.active{color:var(--text);font-weight:600}

/* featured handful on home */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;transition:.18s}
.feat:hover{border-color:var(--accent-dim);transform:translateY(-3px)}
.feat-img{aspect-ratio:16/10;overflow:hidden;border-bottom:1px solid var(--line)}
.feat-img img{width:100%;height:100%;object-fit:cover}
.feat-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.feat-kicker{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:700}
.feat-body h3{font-size:20px;font-weight:800;margin:8px 0 8px}
.feat-body p{font-size:14px;color:var(--muted);flex:1}
.feat-more{display:inline-block;margin-top:16px;font-size:13.5px;font-weight:600;color:var(--accent)}

/* gateways */
.gateways{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.gateway{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;transition:.18s}
.gateway:hover{border-color:var(--accent-dim);transform:translateY(-3px)}
.gw-mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;background:#000}
.gw-mosaic img{aspect-ratio:1/1;object-fit:cover;width:100%;height:100%}
.gw-body{padding:24px 26px 28px}
.gw-body h2{font-size:26px;font-weight:800;margin-bottom:10px}
.gw-body p{font-size:15px;color:var(--muted);margin-bottom:16px}

/* listing grids (industries / sources / per-industry cards) */
.lgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.lcard{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;transition:.18s}
.lcard:hover{border-color:var(--accent-dim);transform:translateY(-3px)}
.lcard-mosaic{background:#000;border-bottom:1px solid var(--line)}
.lcard-mosaic.single img{aspect-ratio:16/10;object-fit:cover;width:100%}
.lcard-mosaic.three{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.lcard-mosaic.three img{aspect-ratio:1/1;object-fit:cover;width:100%;height:100%}
.lcard-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.lcard-body h3{font-size:19px;font-weight:800;margin-bottom:6px}
.lcard-tag{font-size:12.5px;color:var(--accent);font-weight:600;margin-bottom:10px}
.lcard-body p{font-size:14px;color:var(--muted);flex:1}

/* page head + breadcrumb */
.page-head{padding-bottom:0;border-bottom:none}
.crumb{font-size:13px;color:var(--muted);margin-bottom:22px}
.crumb a{color:var(--accent)}
.crumb a:hover{text-decoration:underline}
.crumb span{color:var(--text)}

/* detail page */
.detail-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.detail-prose p{font-size:16px;color:#cdd3d1;margin-bottom:18px}
.detail-prose p:last-child{margin-bottom:0}
.related{margin-top:46px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.related h4{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.chip{display:inline-block;border:1px solid var(--accent-dim);color:var(--accent);
  border-radius:30px;padding:7px 16px;font-size:13.5px;font-weight:600;transition:.18s}
.chip:hover{background:var(--accent);color:#021}
.detail-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:46px;padding-top:36px;border-top:1px solid var(--line)}

/* industry hero */
.industry-hero{display:grid;grid-template-columns:1.15fr 1fr;gap:48px;align-items:center}
.ih-text h1,.ih-text h2{font-size:38px;font-weight:800;letter-spacing:-.01em;margin:12px 0 18px}
.ih-intro p{font-size:15.5px;color:#cdd3d1;margin-bottom:14px}
.ih-intro p:last-child{margin-bottom:0}
.ih-mosaic.three{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;align-items:start;border-radius:14px;overflow:hidden}
.ih-mosaic.three img{aspect-ratio:3/4;object-fit:cover;width:100%;height:auto;display:block;border-radius:8px}
.block-title{font-size:24px;font-weight:800}

/* enhanced-imagery gallery */
.gw-mosaic.three3{grid-template-columns:repeat(3,1fr)}
.egrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.ecard{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ecard img{width:100%;display:block;border-bottom:1px solid var(--line)}
.ecard figcaption{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.ecard h3{font-size:18px;font-weight:700}
@media(max-width:700px){.egrid{grid-template-columns:1fr}}

/* learn / articles */
.art-meta{font-size:13px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.art-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.tag{font-size:11.5px;color:var(--accent);border:1px solid var(--accent-dim);border-radius:20px;padding:3px 10px}
.art-wrap{max-width:760px}
.art-lead{font-size:19px;line-height:1.62;color:#e6eae8;font-weight:500;margin-bottom:26px}
.art-body h2{font-size:22px;font-weight:800;letter-spacing:-.01em;margin:32px 0 12px}
.art .sec-head h1{margin-bottom:10px}
.lcard-body .art-meta{margin-bottom:8px}

/* FAQ */
.faq .wrap{max-width:860px}
.faq h2{font-size:28px;font-weight:800;margin-bottom:22px}
.faq-list details{border:1px solid var(--line);border-radius:10px;padding:2px 18px;margin-bottom:12px;background:var(--panel)}
.faq-list summary{cursor:pointer;font-weight:600;font-size:16px;padding:16px 0;list-style:none}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::before{content:"+";color:var(--accent);font-weight:700;margin-right:12px}
.faq-list details[open] summary::before{content:"–"}
.faq-list details[open] summary{border-bottom:1px solid var(--line)}
.faq-list p{font-size:15px;color:#cdd3d1;padding:14px 0 18px}

/* cookie-consent banner */
.consent{position:fixed;left:16px;right:16px;bottom:16px;z-index:90;max-width:760px;margin:0 auto;
  background:var(--panel-2);border:1px solid var(--line);border-radius:12px;
  padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  font-size:14px;color:var(--muted);box-shadow:0 20px 50px rgba(0,0,0,.6)}
.consent[hidden]{display:none}   /* let the hidden attribute actually hide it (overrides display:flex) */
.consent a{color:var(--accent)}
.consent-btns{display:flex;gap:10px}
.consent .btn{padding:7px 16px;cursor:pointer;font:inherit;line-height:1.2}
.consent .btn:not(.btn-solid){background:transparent;color:var(--accent)}  /* Decline: readable, not the OS default grey */

@media(max-width:900px){
  .feat-grid,.lgrid{grid-template-columns:repeat(2,1fr)}
  .gateways{grid-template-columns:1fr}
  .detail-grid,.industry-hero{grid-template-columns:1fr;gap:28px}
  .ih-text h1,.ih-text h2{font-size:30px}
}
@media(max-width:560px){
  .feat-grid,.lgrid{grid-template-columns:1fr}
  .gw-body h2{font-size:22px}
}
