:root{
  --bg:#0b0e11; --text:#111; --muted:#666; --brand:#1ea896; --light:#f7f8f9; --dark:#0e1114;
  --header-h:88px; --logo-h:72px; --logo-h-mobile:56px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica,Arial,sans-serif;color:var(--text);background:#fff;}
.container{max-width:1080px;margin:0 auto;padding:0 16px}
.site-header{position:fixed;top:0;left:0;right:0;background:#fff;border-bottom:1px solid #eee;z-index:20}
.site-header.header--glass-dark{background:rgba(2,6,23,0.78);border-bottom:1px solid rgba(255,255,255,0.14);backdrop-filter:saturate(180%) blur(8px)}
.site-header.header--glass-dark .brand{color:#fff}
.site-header.header--glass-dark .nav a{color:#fff}
.site-header.header--glass-dark .nav a.cta{color:#fff}
.header-wrap{display:flex;align-items:center;justify-content:space-between;height:var(--header-h)}
 .brand{font-weight:700;color:var(--text);text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.brand picture,.brand img{height:var(--logo-h);width:auto}
.brand .logo{display:none}
.brand .logo--dark{display:inline-flex}
.site-header.header--glass-dark .brand .logo--dark{display:none}
.site-header.header--glass-dark .brand .logo--white{display:inline-flex}
@media (max-width:860px){
  .brand picture,.brand img{height:var(--logo-h-mobile)}
}
.nav-list{display:flex;gap:16px;list-style:none;margin:0;padding:0}
.nav a{color:var(--text);text-decoration:none;padding:8px 10px;border-radius:6px}
.nav a.cta{color:#fff}

/* Gradient links on white header only (exclude glass-dark variant) */
.site-header:not(.header--glass-dark) .nav a:not(.cta){
  background-image:linear-gradient(135deg, #43cea2 0%, #185a9d 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.site-header:not(.header--glass-dark) .nav a:not(.cta):hover{ text-decoration:underline }
.nav-toggle{display:none}
@media (max-width:860px){
  .nav-toggle{display:block;background:none;border:0;font-size:22px}
  .nav-list{display:none;position:absolute;right:16px;top:var(--header-h);background:#fff;border:1px solid #eee;border-radius:8px;padding:8px;flex-direction:column;min-width:220px}
  body.nav-open .nav-list{display:flex}
}

@media (max-width:860px){
  .site-header.header--glass-dark .nav-list{background:rgba(2,6,23,0.92);border-color:rgba(255,255,255,0.12)}
  .site-header.header--glass-dark .nav-list a{color:#fff}
}

.hero{position:relative;min-height:60vh;background-size:cover;background-position:center}
.hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(2,6,23,.30), rgba(2,6,23,.65));pointer-events:none}
.hero-content{position:relative;padding:112px 0 80px;color:#fff;text-align:left}
.hero h1{font-size:42px;margin:0 0 8px}
.hero p{max-width:640px;opacity:.9}
.hero--full{min-height:100vh}
@media (max-width:860px){.hero--full{min-height:70vh}}
.button{display:inline-block;color:#fff;padding:10px 16px;border-radius:8px;text-decoration:none;background-image:linear-gradient(to right, rgba(151,237,171,0.41) 0%, rgba(160,196,243,0.52) 100%) !important}
.button:hover,.nav a.cta:hover{filter:saturate(115%) contrast(105%)}
.button-light{background:#fff;color:var(--text);border:1px solid #eee}

.values{padding:48px 0;border-top:1px solid rgba(255,255,255,0.08)}
.value-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.value-grid article{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:16px;box-shadow:0 4px 10px rgba(0,0,0,0.22)}
.value-grid h3{margin:0;font-weight:700}
@media (max-width:900px){.value-grid{grid-template-columns:1fr}}

/* Services summary helpers */
.values .section-kicker{font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:8px}
.values .service-title{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.values .icon-service{color:#21c48d}
.values .text-link{display:inline-block;margin-top:8px;color:#7ad9c7;text-decoration:none;border-bottom:1px solid rgba(122,217,199,.35)}
.values .text-link:hover{color:#9be6d8;border-bottom-color:rgba(155,230,216,.6)}

.features{padding:24px 0 56px}
.section-header{text-align:center;margin-bottom:16px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cards .card{border:1px solid #eee;border-radius:12px;padding:16px;background:#fff}
@media (max-width:900px){.cards{grid-template-columns:1fr}}

.cta-banner{background:var(--dark);color:#fff}
.cta-wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:28px 16px}
@media (max-width:900px){.cta-wrap{flex-direction:column;align-items:flex-start}}

.site-footer{border-top:1px solid #eee;background:#fafafa}
/* Legacy compact footer row */
.footer-wrap{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:60px}
.footer-nav{display:flex;gap:12px}
.footer-nav a{color:var(--muted);text-decoration:none}

/* Option B: Light multi-column footer with newsletter + socials */
.footer{padding:32px 0 0;background:#fafafa; --footer-border:#e5e7eb}
.footer .footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
@media (max-width:900px){.footer .footer-grid{grid-template-columns:1fr;gap:18px}}
.footer h5{margin:0 0 10px;font-size:16px;font-weight:600;color:#111}
.footer ul{list-style:none;margin:0;padding:0}
.footer a{color:var(--muted);text-decoration:none}
.footer a:hover{color:#111}
/* Text-only info block (newsletter removed) */
.footer .footer-info{background:#fdfdfd;border:1px solid #eee;border-radius:10px;padding:16px}
.footer .footer-info p{margin:0 0 10px;color:var(--muted)}
.footer .footer-info .cta-link{display:inline-block;color:#0f766e;text-decoration:none;border-bottom:1px solid rgba(15,118,110,.25)}
.footer .footer-info .cta-link:hover{color:#0b4f49;border-bottom-color:rgba(15,118,110,.5)}
.footer-bottom{border-top:1px solid var(--footer-border);margin-top:24px}
.footer-bottom .footer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:56px}
@media (max-width:900px){.footer-bottom .footer-row{flex-direction:column;align-items:flex-start;padding:12px 0}}
.footer-legal{display:flex;gap:12px}
.footer-legal a{color:var(--muted);text-decoration:none}
.footer-legal a:hover{color:#111}
.footer-social{display:flex;gap:10px}
.footer-social a{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;border:1px solid #e5e7eb;color:#444}
.footer-social a:hover{background:#fff}

/* Ensure simple site footer gets consistent bottom divider */
.site-footer .footer-bottom{border-top:1px solid #e5e7eb;margin-top:24px}

/* Apply site gradient to links (exclude social icons that depend on currentColor) */
.footer .footer-grid a,
.footer .footer-legal a,
.footer .footer-info .cta-link{
  background-image:linear-gradient(135deg, #43cea2 0%, #185a9d 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.footer .footer-grid a:hover,
.footer .footer-legal a:hover,
.footer .footer-info .cta-link:hover{ text-decoration:underline }
/* Social icons: no discs; icons themselves carry gradient via SVG */
.footer .footer-social a{
  background-image:none;
  color:#444; /* used only when SVG relies on currentColor */
  border:1px solid #e5e7eb;
}
.footer .footer-social a:hover{ background:#fff }

/* --- Simple footer (site-footer) — plain legal links with underline on hover */
.site-footer .footer-legal a {
  background-image:none;
  -webkit-background-clip:initial; background-clip:initial; color:var(--muted);
  text-decoration:none;
}
.site-footer .footer-legal a:hover,
.site-footer .footer-legal a:focus { text-decoration: underline; color:#111; }

/* Simple footer: same treatment — no discs */
.site-footer .footer-social a { background-image:none; color:#444; border:1px solid #e5e7eb }
.site-footer .footer-social a:hover { background:#fff }

/* Helpers */

/* Keys Section */
.keys{padding:48px 0 48px}
.keys .section__title{text-align:center;margin-bottom:32px;color:#fff;font-size:32px;line-height:1.2}
.keys.gradient-green-dark{color:#fff}
.keys.gradient-ocean-hue{color:#fff}

/* Modal (accessible) */
.modal{position:fixed;inset:0;display:none}
.modal[aria-hidden="false"]{display:block}
.modal .backdrop{position:absolute;inset:0;background:rgba(2,6,23,0.6);backdrop-filter:saturate(180%) blur(4px)}
.modal .dialog{position:relative;margin:10vh auto 0;max-width:560px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 30px rgba(2,6,23,0.25);padding:18px}
.modal .dialog header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.modal .dialog h3{margin:0;font-size:20px}
.modal .dialog .close{background:none;border:0;font-size:22px;line-height:1;cursor:pointer;color:#111}
.modal .dialog .actions{display:flex;gap:10px;margin-top:12px}
.modal .dialog .actions .button{border-radius:8px}

/* Five-card grid layout */
.cards-5{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}
@media (max-width:1200px){.cards-5{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.cards-5{grid-template-columns:1fr}}

/* Numeral + text styling inside cards */
.card__num{font-size:32px;font-weight:700;line-height:1;color:#1f2937;opacity:.25;margin-bottom:8px}
.card__title{font-size:18px;font-weight:600;margin:0 0 6px}
.card__text{font-size:16px;line-height:1.5;color:#374151}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* Gradient utilities */
.gradient-green-dark{background:linear-gradient(135deg, rgba(16,185,129,0.30) 0%, rgba(2,44,34,0.65) 55%, rgba(15,23,42,0.85) 100%)}
.gradient-ocean-hue{background-image:linear-gradient(to right, rgba(151,237,171,0.41) 0%, rgba(160,196,243,0.52) 100%) !important}
.h-gradient-ocean-hue:hover{background-image:linear-gradient(to right, rgba(151,237,171,0.41) 0%, rgba(160,196,243,0.52) 100%) !important}
/* Test gradient: green-blue */
.gradient-green-blue{background-image:linear-gradient(to right, #43cea2, #185a9d) !important}
.h-gradient-green-blue:hover{background-image:linear-gradient(to right, #43cea2, #185a9d) !important}

/* Scroll indicators */
.scroll-indicator{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);color:#fff;text-decoration:none;font-size:22px;opacity:.9;animation:arrow-bob 1s ease-in-out infinite}
.scroll-indicator:hover{opacity:1}
@keyframes arrow-bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-10px)}}
.split, .section.keys, .ticker, .values{scroll-margin-top:var(--header-h)}
.scroll-top{position:fixed;right:16px;bottom:18px;width:44px;height:44px;border-radius:999px;border:none;display:none;align-items:center;justify-content:center;cursor:pointer;background-image:linear-gradient(to right, #43cea2, #185a9d);color:#fff;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.scroll-top:hover{filter:saturate(115%) contrast(105%);transform:translateY(-1px);box-shadow:0 10px 24px rgba(0,0,0,.22)}
.scroll-top.show{display:flex}
.scroll-top{font-size:13px;letter-spacing:0;line-height:1}
.scroll-top svg{width:22px;height:22px;display:block}
.scroll-top svg path{stroke-width:2.5}
.text-gradient-ocean{background:linear-gradient(135deg, #00D1FF 0%, #0EA5E9 35%, #2563EB 70%, #0B1E3A 100%);-webkit-background-clip:text;background-clip:text;color:transparent}

/* Green-blue text gradient utility */
.text-gradient-green-blue{background-image:linear-gradient(135deg, #43cea2 0%, #185a9d 100%);-webkit-background-clip:text;background-clip:text;color:transparent}

/* Text rotator */
.hero-rotator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:1}
.text-rotater{display:inline-block;font-weight:700;font-size:42px;line-height:1.1;color:#fff}
.text-rotater.fade{transition:opacity .35s ease}
/* Blinking pipe cursor shown after the rotator text */
.text-rotater::after{content:'|';margin-left:6px;opacity:1;animation:blink 1s steps(1,end) infinite}
@keyframes blink{50%{opacity:0}}

/* Promo blocks */
.promo{background:#fff;color:#111;border-radius:0}
.promo h3{margin:0 0 6px;font-weight:600;font-size:24px;line-height:1.3}
.promo .promo-sub{display:block;opacity:.9}
.promo-border{border:1px solid #eee}
.promo-dark{background:#2d2f33;color:#fff;border:1px solid #3a3d42;border-radius:0}
.promo-dark h3{color:#fff}
.promo-dark .promo-sub{color:#e5e7eb}
.promo-full{width:100%}
.p-4{padding:16px}
.p-3{padding:12px}
.mb-5{margin-bottom:32px}
@media (min-width:900px){.p-md-5{padding:32px}}
@media (min-width:900px){.p-md-4{padding:20px}}
.row{display:flex;flex-wrap:wrap;gap:16px}
.no-wrap-md{flex-wrap:wrap}
@media (min-width:900px){.no-wrap-md{flex-wrap:nowrap}}
.justify-between{justify-content:space-between}
.align-items-center{align-items:center}
.col-12{flex:1 1 100%}
.col-lg{flex:1 1 auto}
.col-lg-auto{flex:0 0 auto}
.mt-4{margin-top:16px}
@media (min-width:900px){.mt-lg-0{margin-top:0 !important}}
.m-0{margin:0 !important}
.button-large{padding:14px 20px;font-size:18px}
.button-circle,.button-rounded{border-radius:999px}

/* Emphasis spans in promo heading to mimic screenshot */
.promo__em{font-weight:400;letter-spacing:.1px;display:inline-block;background:#23262b;color:#fff;padding:1px 7px;margin:0 4px;border-radius:6px;border:1px solid #4b4f56}

/* Split section */
.split{padding:48px 0}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
@media (max-width:900px){.split-grid{grid-template-columns:1fr}}
.split h2{font-size:32px;line-height:1.2;margin:0 0 12px}
.split p{color:var(--muted);margin:0 0 16px}
.image-card{border:1px solid #eee;border-radius:12px;overflow:hidden;background:#fff}
.image-card img{display:block;width:100%;height:auto;transition:transform .3s ease}
.image-card:hover img{transform:scale(1.02)}
.image-caption{font-size:13px;color:var(--muted);padding:8px 12px;border-top:1px solid #eee;opacity:.7}

/* Ticker (Canvas-style marquee) */
.ticker{padding:12px 0;color:#fff}
.ticker{position:relative;overflow:hidden;width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);padding-left:0;padding-right:0}
.ticker{--ticker-edge:40px}
/* edge fade overlays to soften ticker edges */
.ticker::before,.ticker::after{content:"";position:absolute;top:0;bottom:0;width:var(--ticker-edge,40px);pointer-events:none;z-index:1}
.ticker::before{left:0;background:linear-gradient(to right, rgba(2,6,23,0.55), rgba(2,6,23,0))}
.ticker::after{right:0;background:linear-gradient(to left, rgba(2,6,23,0.55), rgba(2,6,23,0))}
.ticker-track{display:flex;gap:24px;align-items:center;white-space:nowrap;will-change:transform;animation:ticker-move 28s linear infinite}
.ticker.pause-on-hover:hover .ticker-track{animation-play-state:paused}
.ticker-item{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;background:rgba(15,23,42,0.35);border:1px solid rgba(255,255,255,0.18);color:#fff;font-weight:600;letter-spacing:.2px;text-decoration:none}
.ticker-item svg{width:16px;height:16px;display:block;opacity:.9}
/* pause state via class for accessibility */
.ticker.paused .ticker-track{animation-play-state:paused}
/* small control button inside ticker */
  /* Move content fully across from right edge to left edge */
/* Seamless marquee: duplicates in track make width ~200%;
   moving from 0 to -50% enters from right overlay and exits left overlay */
@keyframes ticker-move{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Global text-link style, used by card “Learn more” links */
.text-link{display:inline-block;margin-top:8px;color:#7ad9c7;text-decoration:none;border-bottom:1px solid rgba(122,217,199,.35)}
.text-link:hover{color:#9be6d8;border-bottom-color:rgba(155,230,216,.6)}
@media (max-width:900px){.ticker-track{gap:16px;animation-duration:30s}.ticker-item{padding:8px 12px;font-weight:600}}

/* Responsive refinements for ~1024px viewport */
@media (min-width:900px) and (max-width:1200px){
  .hero h1{font-size:52px}
  .text-rotater{font-size:40px}
  .split-grid{grid-template-columns:1.25fr .75fr}
  .split-grid > div:first-child{max-width:640px}
  .cards-5{gap:24px}
  .card__title{font-size:17px;letter-spacing:.2px;font-weight:700}
}

/* Accessibility: visible focus outlines */
a:focus-visible,.nav a:focus-visible,.button:focus-visible,.scroll-top:focus-visible{
  outline:2px solid #43cea2; outline-offset:2px;
}

/* Services summary grid (2×4 clickable cards) */
.services-summary{padding:32px 0}
.services-summary .section__title{margin-bottom:12px}
.services-summary .section__lead{color:#4b5563;margin-bottom:20px}
.cards.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cards.cards-4 .card{display:block;text-decoration:none;color:inherit;border:1px solid rgba(0,0,0,0.08);border-radius:12px;padding:16px;background:#fff;box-shadow:0 4px 10px rgba(0,0,0,.12)}
.cards.cards-4 .card:hover{box-shadow:0 8px 18px rgba(0,0,0,.28);transform:translateY(-2px)}
.cards.cards-4 .card h4{font-size:16px;margin:0 0 6px}
.cards.cards-4 .card p{margin:0;color:#6b7280}
@media (max-width:1024px){.cards.cards-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cards.cards-4{grid-template-columns:1fr}}

/* Coming soon teaser split */
.teaser{padding:28px 0}
.teaser .section__title{margin-bottom:8px}
.teaser .section__lead{color:#4b5563;margin-bottom:12px}
.teaser .image-card{border-radius:12px;overflow:hidden;border:1px solid #e5e7eb}
.teaser .button-light{border-radius:12px}

/* Counters block */
.counters{padding:28px 0}
.counters .lead{color:#374151;margin-bottom:16px}
.counter-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.counter{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:16px;text-align:center}
.counter .num{font-size:28px;font-weight:800;color:#0f172a;margin-bottom:6px}
.counter .label{color:#6b7280}
@media (max-width:1024px){.counter-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.counter-grid{grid-template-columns:1fr}}

/* Promo dark CTA refinement (square edges per Canvas spec) */
.promo-dark{background:#2d2f33;color:#fff;border-radius:0}
.promo-dark .note{font-size:13px;opacity:.85}
/* Use default Canvas button radius to match hero button */
/* Footer theme variables and color scheme */
:root {
  --footer-bg: #f7f9fc; /* light neutral tint */
  --footer-text: #2b2f36;
  --footer-heading: #111827;
  --footer-link: #0c66ff; /* default accent; adjust to brand later */
  --footer-link-hover: #0940b8;
  --footer-border: #e6eef7;
}

/* Base footer theming */
.footer {
  background-color: var(--footer-bg);
  color: var(--footer-text);
  border-top: 1px solid var(--footer-border);
}

.footer h5 {
  color: var(--footer-heading);
}

.footer a {
  color: var(--footer-link);
  text-decoration: none;
}

.footer a:hover,
.footer a:focus {
  color: var(--footer-link-hover);
  text-decoration: underline;
}

/* Bottom bar refinement */
.footer .footer-row {
  border-top: 1px solid var(--footer-border);
}

.footer .footer-legal a {
  color: var(--footer-text);
  opacity: 0.8;
}

.footer .footer-legal a:hover,
.footer .footer-legal a:focus {
  opacity: 1;
}

.footer .footer-social a {
  color: var(--footer-link);
}

/* Optional dark variant for future use */
.footer.footer--dark {
  --footer-bg: #0f172a;
  --footer-text: #cbd5e1;
  --footer-heading: #e2e8f0;
  --footer-link: #93c5fd;
  --footer-link-hover: #bfdbfe;
  --footer-border: #1f2937;
}