@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Poppins:wght@500;600;700&family=Fira+Code:wght@400;500&display=swap");

/* =========================================================
   1) THEME TOKENS (logo colors & scaling)
========================================================= */
:root{
  /* Brand */
  --mnb-green:#6abd45;
  --mnb-navy:#2c4c75;
  --mnb-aqua:#00CFFF;
  --mnb-ink:#122036;
  --mnb-muted:#667693;

  /* Surfaces */
  --mnb-bg:#F5F7FA;
  --mnb-surface:#FFFFFF;
  --mnb-line:#E8EEF6;

  /* Shadows */
  --mnb-shadow:0 8px 22px rgba(0,0,0,.10);
  --mnb-shadow-2:0 18px 44px rgba(0,0,0,.14);
  --mnb-shadow-3:0 26px 70px rgba(0,0,0,.18);
  --mnb-shadow-hero:rgba(0,0,0,.15) 0px 6px 30px;

  /* Effects */
  --mnb-ring:rgba(106,189,69,.25);
  --mnb-gradient:linear-gradient(to right, var(--mnb-green), var(--mnb-navy));
  --mnb-gradient-soft:linear-gradient(180deg, rgba(106,189,69,.06), rgba(44,76,117,.06));
  --mnb-ease:cubic-bezier(.2,.7,.2,1);

  /* Radii */
  --mnb-radius:14px;
  --mnb-radius-lg:18px;

  /* Spacing scale */
  --mnb-s-1:.25rem; --mnb-s-2:.5rem; --mnb-s-3:.75rem; --mnb-s-4:1rem;
  --mnb-s-5:1.5rem; --mnb-s-6:2rem; --mnb-s-7:3rem; --mnb-s-8:4rem; --mnb-s-9:5rem;

  /* Type scale */
  --mnb-fs-sm:.9rem; --mnb-fs-base:1rem; --mnb-fs-lead:1.0625rem;
  --mnb-fs-h6:1rem; --mnb-fs-h5:1.125rem; --mnb-fs-h4:1.25rem;
  --mnb-fs-h3:1.5rem; --mnb-fs-h2:2rem; --mnb-fs-h1:2.85rem;

  --mnb-lh-tight:1.18;
  --mnb-lh-copy:1.65;

  /* Layout constants */
  --mnb-logo-h:56px; --mnb-logo-h-sm:60px;
  --mnb-slide-ms:5200ms;
  --mnb-kenburns-scale:1.08;
  --mnb-nav-h:64px;
  --mnb-hero-overlap:clamp(24px, 7vw, 84px);
  --mnb-border-strong:1px solid var(--mnb-line);

  /* Fonts */
  --mnb-font-sans: "Inter", "Poppins", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mnb-font-serif: "Merriweather", Georgia, serif;
  --mnb-font-mono: "Fira Code", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}



/* 1a) Safe viewport to avoid scrollbar jump on full-bleed */
:root{ --vw-safe: calc(100vw - (100vw - 100%)); }


@supports (width: 100svw){ :root{ --vw-safe: 100svw; } }



/* =========================================================
   2) BASE RESETS & TYPOGRAPHY
========================================================= */
*{ box-sizing:border-box; font-family:var(--mnb-font-sans); }


html,body{ margin:0; padding:0; }


html, body{ overflow-x: clip; }


@supports not (overflow: clip){ html, body{ overflow-x:hidden; } }



body{
  color:var(--mnb-ink);
  line-height:var(--mnb-lh-copy);
  font-size:var(--mnb-fs-base);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  background:
    radial-gradient(900px 400px at 0% 0%, rgba(0,207,255,.06), transparent 60%),
    radial-gradient(900px 420px at 100% 100%, rgba(106,189,69,.07), transparent 62%),
    linear-gradient(180deg,#ffffff 0%, #f7fafc 100%);
}



img{ max-width:100%; height:auto; display:block; }


svg{ display:block; }


a{ color:var(--mnb-navy); text-decoration:none; }


a:hover{ opacity:.95; }



h1,h2,h3,h4,h5,h6{
  font-weight:700;
  line-height:var(--mnb-lh-tight);
  margin:0 0 .5em;
}


h1{ font-size:var(--mnb-fs-h1) }


h2{ font-size:var(--mnb-fs-h2) }


h3{ font-size:var(--mnb-fs-h3) }


h4{ font-size:var(--mnb-fs-h4) }


h5{ font-size:var(--mnb-fs-h5) }


h6{ font-size:var(--mnb-fs-h6) }



p{ margin:0 0 1em; }


small, .mnb-muted{ color:var(--mnb-muted); }



code, pre, kbd, samp{ font-family:var(--mnb-font-mono); }


pre{ padding: .85rem 1rem; background:#0b1422; color:#e8eef6; border-radius:12px; overflow:auto; }



/* Focus ring */
:where(a,button,[role="button"],input,select,textarea):focus-visible{
  outline:3px solid var(--mnb-ring); outline-offset:2px; border-radius:12px;
}



/* Container + section spacing */
.mnb-container{ width:min(1200px, 100% - 2.5rem); margin-inline:auto; }


section{ padding: var(--mnb-s-7) 0; }



/* Link underline helper */
.mnb-link-ani{ position:relative; }


.mnb-link-ani::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:currentColor; transition:width .22s var(--mnb-ease);
}


.mnb-link-ani:hover::after{ width:100%; }



/* Visually hidden (a11y) */
.mnb-visually-hidden{
  position:absolute !important; height:1px; width:1px; overflow:hidden;
  clip:rect(1px,1px,1px,1px); white-space:nowrap; border:0; padding:0; margin:-1px;
}



/* =========================================================
   3) GLOBAL UTILS
========================================================= */
.mnb-surface{ background:var(--mnb-surface); border:var(--mnb-border-strong); border-radius:var(--mnb-radius); }


.mnb-shadow{ box-shadow:var(--mnb-shadow); }


.mnb-shadow-2{ box-shadow:var(--mnb-shadow-2); }


.mnb-shadow-3{ box-shadow:var(--mnb-shadow-3); }


.mnb-gradient{ background:var(--mnb-gradient); color:#fff; }


.mnb-pill{ border-radius:999px; padding:.4rem .8rem; }


.mnb-btn{ display:inline-flex; align-items:center; gap:.5rem; padding:.75rem 1.1rem; border-radius:12px; font-weight:700; border:1px solid transparent; cursor:pointer; }


.mnb-btn-primary{ background:var(--mnb-navy); color:#fff; box-shadow:var(--mnb-shadow); }


.mnb-btn-primary:hover{ filter:brightness(1.06); transform:translateY(-1px); transition:all .16s var(--mnb-ease); }


.mnb-btn-outline{ background:#fff; color:var(--mnb-navy); border-color:#cfd9e8; }


.mnb-grid{ display:grid; gap:var(--mnb-s-4); }



/* =========================================================
   4) FULL-BLEED / SLIDER FIXES
========================================================= */
.mnb-slider{ width: var(--vw-safe); left:50%; transform:translateX(-50%); overflow:hidden; position:relative; }



/* Prevent section bleed on fancy backgrounds */
.mnb-hero, .mnb-tech-bubbles{ overflow-x: clip; }



/* =========================================================
   5) TOPBAR + BRAND ROW
========================================================= */
.mnb-topbar{ background:var(--mnb-surface); border-bottom:var(--mnb-border-strong); }


.mnb-utilbar{
  background:var(--mnb-gradient);
  border-bottom:1px solid rgba(255,255,255,.25);
  color:#fff; font-size:.92rem; box-shadow:var(--mnb-shadow-hero);
}


.mnb-utilbar a{ color:#fff; }


.mnb-utilbar-grid{ display:flex; align-items:center; justify-content:space-between; padding:.5rem 0; }


.mnb-utilbar-left, .mnb-utilbar-right{ display:flex; align-items:center; gap:1rem; }



.mnb-social{
  display:inline-grid; place-items:center; width:32px; height:32px; border-radius:10px;
  background:rgba(255,255,255,.18); color:#fff;
  transition:transform .18s var(--mnb-ease), background .18s var(--mnb-ease);
}


.mnb-social:hover{ background:rgba(255,255,255,.28); transform:translateY(-1px); }



.mnb-brandrow{
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:1.25rem;
  padding:1.5rem 0 1.4rem 0;
  background:
    radial-gradient(800px 320px at 100% 0%, rgba(0,207,255,.06), transparent 60%),
    radial-gradient(700px 300px at 0% 100%, rgba(106,189,69,.08), transparent 60%);
}


.mnb-brand-logo img{ height:var(--mnb-logo-h); object-fit:contain; filter:drop-shadow(0 2px 8px rgba(0,0,0,.08)); }


.mnb-brand-contacts{ display:flex; align-items:center; justify-content:flex-end; gap:1.25rem; }



.mnb-chip{ display:grid; grid-template-columns:auto 1fr; gap:.6rem; align-items:center; }


.mnb-chip-ico{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center;
  background:conic-gradient(from 180deg, rgba(106,189,69,.18), rgba(44,76,117,.18));
  color:var(--mnb-green); box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}


.mnb-chip strong{ color:var(--mnb-navy); }


.mnb-chip .mnb-muted{ font-size:.85rem; color:var(--mnb-muted); }



.mnb-divider{ width:1px; height:44px; background:#DEE6F2; }



.mnb-brand-cta{
  display:inline-flex; align-items:center; gap:.5rem; justify-content:center;
  padding:.85rem 1.2rem; border-radius:999px; font-weight:800;
  background:var(--mnb-navy); color:#fff;
  box-shadow:var(--mnb-shadow-hero);
  border:1px solid rgba(255,255,255,.3);
  transition:transform .16s var(--mnb-ease), filter .16s var(--mnb-ease);
}


.mnb-brand-cta:hover{ filter:brightness(1.06); transform:translateY(-1px); }



/* =========================================================
   6) STICKY NAV PILL
========================================================= */
.mnb-sticky-wrap{
  position:sticky; top:0; z-index:120; padding:.35rem 0;
  background:linear-gradient(180deg, rgb(253 253 254), rgba(245, 247, 250, 0));
  backdrop-filter:saturate(160%) blur(6px);
}


.mnb-sticky-sentinel{ height:0; }


.mnb-mainnav-wrap{ position:relative; margin-top:-0.5rem; }


.mnb-mainnav{
  background:var(--mnb-gradient);
  border-radius:16px; box-shadow:var(--mnb-shadow-hero);
  translate:0 6px;
  transition:translate .25s var(--mnb-ease), box-shadow .25s var(--mnb-ease), border-radius .25s var(--mnb-ease), background-position .25s var(--mnb-ease);
  background-size:200% 100%; background-position:0% 0%;
}


.mnb-mainnav.mnb-is-stuck{ box-shadow:0 10px 26px rgba(0,0,0,.2); border-radius:12px; }


.mnb-mainnav:hover{ background-position:100% 0%; }



.mnb-navwrap{ display:flex; align-items:center; padding:.5rem .65rem; gap:.65rem; }


.mnb-hamb{
  display:none; background:rgba(255,255,255,.12); color:#fff; border:0;
  border-radius:10px; padding:.6rem .85rem; font-weight:800; cursor:pointer;
}


.mnb-menu{ list-style:none; margin:0; padding:0; display:flex; gap:.25rem; align-items:center; flex:1; flex-wrap:wrap; }


.mnb-menu a{
  color:#fff; font-weight:800; font-size:.98rem; display:block;
  padding:.7rem 1rem; border-radius:10px; letter-spacing:.2px;
  transition:background .18s var(--mnb-ease), transform .18s var(--mnb-ease);
}


.mnb-menu a:hover{ background:rgba(255,255,255,.16); transform:translateY(-1px); }


.mnb-menu a.mnb-active{ background:#ffffff; color:var(--mnb-navy); }



@media (max-width: 880px){
  .mnb-hamb{ display:inline-flex; }
  .mnb-menu{
    display:none; flex-direction:column; width:100%;
    background:rgba(255,255,255,.10); border-radius:12px; padding:.4rem;
  }
  .mnb-menu.mnb-open{ display:flex; }
}



/* =========================================================
   7) BUBBLE HELPERS (for hero layout-B)
========================================================= */
.mnb-bubble{
  position:absolute; z-index:2; pointer-events:none;
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:10px 12px; border-radius:999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.28);
  color:#fff;
  box-shadow: 0 10px 24px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.18);
  animation: mnb-bob 6.5s ease-in-out infinite;
}


.mnb-bubble i{ font-size:1rem; filter: drop-shadow(0 1px 1px rgba(0,0,0,.35)); }


.mnb-bubble small{ font-weight:700; letter-spacing:.02em; opacity:.9; }



.mnb-b-sm{ font-size:.8rem; padding:8px 10px; }


.mnb-b-md{ font-size:.9rem; padding:10px 12px; }


.mnb-b-lg{ font-size:1rem;  padding:12px 14px; }



.mnb-col-primary{ background:rgba(0, 180, 255, .18); border-color: rgba(0, 180, 255, .35); }


.mnb-col-accent{  background:rgba(106,189,69,.18); border-color: rgba(106,189,69,.35); }


.mnb-col-white{   background:rgba(255,255,255,.18); border-color: rgba(255,255,255,.35); }


.mnb-col-muted{   background:rgba(44,76,117,.24);  border-color: rgba(255,255,255,.24); }



@keyframes mnb-bob{ 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-8px) } }


@media (prefers-reduced-motion: reduce){ .mnb-bubble{ animation:none } }



/* =========================================================
   8) PAGE BACKDROP (gentle aurora behind all sections)
========================================================= */
.mnb-page-bg{
  position: fixed; inset: -10% -10% 0 -10%;
  z-index: -1; pointer-events: none;
  background:
    radial-gradient(900px 500px at 12% -5%, rgba(0,207,255,.06), transparent 60%),
    radial-gradient(1100px 700px at 100% 110%, rgba(106,189,69,.08), transparent 62%);
  opacity:.9;
  animation: mnb-page-sway 48s ease-in-out infinite alternate;
}


@keyframes mnb-page-sway{
  0%   { transform: translateY(-1.2%) rotate(0.001deg); }
  100% { transform: translateY( 1.2%) rotate(0.001deg); }
}


@media (prefers-reduced-motion: reduce){ .mnb-page-bg{ animation:none; } }



/* =========================================================
   9) REUSABLE SECTION DIVIDERS
========================================================= */
.mnb-divider-band{
  position: relative; height: 52px; overflow: hidden; isolation: isolate;
}



/* Wave */
.mnb-divider--wave::before{
  content:""; position:absolute; inset:-1px 0 0 0;
  background:
    radial-gradient(1200px 120px at 50% 0%, rgba(0,0,0,.06), transparent 60%),
    #fff;
  -webkit-mask:
    url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="1440" height="120" viewBox="0 0 1440 120" preserveAspectRatio="none"><path d="M0,40 C240,120 480,0 720,60 C960,120 1200,20 1440,80 L1440,0 L0,0 Z" fill="black"/></svg>')
    center/100% 100% no-repeat;
          mask:
    url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="1440" height="120" viewBox="0 0 1440 120" preserveAspectRatio="none"><path d="M0,40 C240,120 480,0 720,60 C960,120 1200,20 1440,80 L1440,0 L0,0 Z" fill="black"/></svg>')
    center/100% 100% no-repeat;
  opacity:.9;
}



/* Tilt (angled slice) */
.mnb-divider--tilt::before{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.04), transparent);
  transform: skewY(-2.2deg);
  transform-origin: top left;
}



/* Curve (soft scallops) */
.mnb-divider--curve::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(80% 60% at 50% 0%, rgba(0,0,0,.05), transparent 70%),
    radial-gradient(40% 100% at 0% 0%, rgba(0,0,0,.04), transparent 70%),
    radial-gradient(40% 100% at 100% 0%, rgba(0,0,0,.04), transparent 70%);
}



/* =========================================================
   10) RESPONSIVE TWEAKS
========================================================= */
@media (max-width: 1024px){
  :root{ --mnb-logo-h:52px; }
  .mnb-brandrow{ grid-template-columns: 1fr; row-gap: .75rem; }
  .mnb-brand-contacts{ justify-content:flex-start; flex-wrap:wrap; }
}



@media (max-width: 720px){
  :root{ --mnb-fs-h1:2.3rem; --mnb-fs-h2:1.7rem; --mnb-fs-h3:1.35rem; }
  .mnb-container{ width: min(100%, 100% - 1.5rem); }
  section{ padding: var(--mnb-s-6) 0; }
  .mnb-brand-logo img{ height:var(--mnb-logo-h-sm); }
  .mnb-divider{ display:none; }
}



/* =========================================================
   11) PRINT NICE-TO-HAVES
========================================================= */
@media print{
  .mnb-sticky-wrap, .mnb-page-bg{ display:none !important; }
  a{ text-decoration: underline; }
}

/* ==========================================================================
   MNB Bundle CSS — v1.0
   Author: ChatGPT (GPT-5 Thinking)
   Structure:
   - @layer reset, tokens, base, utilities, components, motion, pages
   Notes:
   - Keep page-specific overrides inside @layer pages to lower specificity pressure.
   - Utilities are mobile-first; responsive variants use media queries.
   - Follow prefers-reduced-motion where possible.
   ========================================================================== */

/* --------------------------------------
   Cascade Layers
-------------------------------------- */
@layer reset, tokens, base, utilities, components, motion, pages;

/* --------------------------------------
   1) Reset
-------------------------------------- */
@layer reset {
  *,*::before,*::after { box-sizing: border-box; }
  * { margin: 0; }
  html,body { height: 100%; }
  body { line-height: 1.5; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
  img, picture, video, canvas, svg { display: block; max-width: 100%; }
  input, button, textarea, select { font: inherit; }
  p, h1, h2, h3, h4, h5, h6 { overflow-wrap: anywhere; }
  :root { color-scheme: light dark; }
}



/* --------------------------------------
   2) Design Tokens (CSS variables)
-------------------------------------- */
@layer tokens {
  :root {
    /* Colors */
    --mnb-bg:         #0b0e14;
    --mnb-surface:    #111827;
    --mnb-panel:      #0f172a;
    --mnb-elev:       #1f2937;
    --mnb-text:       #e5e7eb;
    --mnb-subtext:    #cbd5e1;
    --mnb-muted:      #94a3b8;
    --mnb-primary:    #6366f1; /* indigo-500 */
    --mnb-primary-600:#4f46e5;
    --mnb-secondary:  #06b6d4; /* cyan-500 */
    --mnb-accent:     #f43f5e; /* rose-500 */
    --mnb-success:    #10b981;
    --mnb-warning:    #f59e0b;
    --mnb-danger:     #ef4444;
    --mnb-border:     #2d3748;
    --mnb-ring:       #93c5fd;

    /* Gradients */
    --mnb-grad-1: linear-gradient(135deg, #6366f1, #06b6d4);
    --mnb-grad-2: radial-gradient(1200px 800px at 20% -10%, rgba(99,102,241,.25), transparent 60%),
                  radial-gradient(1200px 800px at 80% 120%, rgba(244,63,94,.18), transparent 60%);

    /* Typography */
    --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Inter, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji";
    --step--1: 0.875rem;
    --step-0:  1rem;
    --step-1:  1.125rem;
    --step-2:  1.25rem;
    --step-3:  1.5rem;
    --step-4:  1.875rem;
    --step-5:  2.25rem;
    --step-6:  3rem;

    /* Spacing scale (4px base) */
    --space-1: .25rem;
    --space-2: .5rem;
    --space-3: .75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;

    /* Radii & Shadows */
    --radius-sm: .375rem;
    --radius: .75rem;
    --radius-xl: 1rem;
    --shadow-sm: 0 1px 2px rgba(0,0,0,.12);
    --shadow:    0 10px 30px rgba(0,0,0,.25);
    --shadow-xl: 0 20px 60px rgba(0,0,0,.35);

    /* Layout */
    --container: 1200px;
    --gutter: 1rem;
    --z-1: 10; --z-2: 20; --z-3: 30; --z-4: 40; --z-5: 50; --z-max: 9999;

    /* Motion */
    --ease: cubic-bezier(.22,.61,.36,1);
    --speed-fast: 150ms;
    --speed: 300ms;
    --speed-slow: 600ms;
  }

  @media (min-width: 768px) {
    :root { --container: 1240px; }
  }
}



/* --------------------------------------
   3) Base (html/body/typography/links/etc)
-------------------------------------- */
@layer base {
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--font-sans);
    font-size: var(--step-0);
    color: var(--mnb-text);
    background: var(--mnb-bg);
    background-image: var(--mnb-grad-2);
  }
  a { color: var(--mnb-primary); text-decoration: none; transition: color var(--speed) var(--ease); }
  a:hover { color: var(--mnb-primary-600); }
  .link-colored { color: var(--mnb-secondary); }
  .link-colored:hover { color: var(--mnb-accent); }
  .container {
    width: min(100% - 2*var(--gutter), var(--container));
    margin-inline: auto;
  }
  .surface     { background: var(--mnb-surface); border: 1px solid var(--mnb-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); }
  .panel       { background: linear-gradient(180deg, rgba(17,24,39,.85), rgba(17,24,39,.7)); backdrop-filter: blur(10px); border: 1px solid rgba(148,163,184,.2); border-radius: var(--radius-xl); }
  .elev        { background: var(--mnb-elev); border: 1px solid rgba(148,163,184,.15); border-radius: var(--radius); box-shadow: var(--shadow); }

  /* Headings */
  h1 { font-size: var(--step-6); line-height: 1.05; letter-spacing:-.01em; }
  h2 { font-size: var(--step-5); line-height: 1.1; }
  h3 { font-size: var(--step-4); line-height: 1.15; }
  h4 { font-size: var(--step-3); }
  h5 { font-size: var(--step-2); }
  h6 { font-size: var(--step-1); }
  p  { font-size: var(--step-0); color: var(--mnb-subtext); }

  /* Focus ring */
  :focus-visible {
    outline: 2px solid var(--mnb-ring);
    outline-offset: 2px;
    transition: outline-color var(--speed) var(--ease);
  }

  /* Vertical rule */
  .vr { width:1px; background: var(--mnb-border); align-self: stretch; }
}



/* --------------------------------------
   4) Utilities (spacing, layout, display, etc)
-------------------------------------- */
@layer utilities {
  /* Spacing (margin/padding) */
  .m-0{margin:0}.mt-1{margin-top:var(--space-1)}.mb-1{margin-bottom:var(--space-1)}
  .mt-2{margin-top:var(--space-2)}.mb-2{margin-bottom:var(--space-2)}
  .mt-3{margin-top:var(--space-3)}.mb-3{margin-bottom:var(--space-3)}
  .mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}
  .mt-6{margin-top:var(--space-6)}.mb-6{margin-bottom:var(--space-6)}
  .mt-8{margin-top:var(--space-8)}.mb-8{margin-bottom:var(--space-8)}
  .p-0{padding:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}
  .px-4{padding-inline:var(--space-4)}.py-4{padding-block:var(--space-4)}.py-6{padding-block:var(--space-6)}.py-8{padding-block:var(--space-8)}

  /* Display / Flex / Grid */
  .d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.d-none{display:none}
  .flex-col{flex-direction:column}.flex-center{align-items:center;justify-content:center;gap:var(--space-4)}
  .flex-between{align-items:center;justify-content:space-between}
  .grid-2{grid-template-columns:repeat(2, minmax(0,1fr)); gap: var(--space-6);}
  .grid-3{grid-template-columns:repeat(3, minmax(0,1fr)); gap: var(--space-6);}
  .grid-auto{grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap: var(--space-6);}
  .gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}

  /* Positioning */
  .pos-rel{position:relative}.pos-abs{position:absolute}.pos-fix{position:fixed}
  .top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}
  .z-1{z-index:var(--z-1)}.z-2{z-index:var(--z-2)}.z-3{z-index:var(--z-3)}.z-max{z-index:var(--z-max)}

  /* Sizing */
  .w-100{width:100%}.h-100{height:100%}.min-h-50vh{min-height:50vh}.min-h-100vh{min-height:100vh}

  /* Radius & Shadow */
  .rounded{border-radius:var(--radius)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-sm{border-radius:var(--radius-sm)}
  .shadow{box-shadow:var(--shadow)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-xl{box-shadow:var(--shadow-xl)}

  /* Text utilities */
  .text-center{text-align:center}.text-muted{color:var(--mnb-muted)}
  .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

  /* Colored backgrounds */
  .bg-surface{background:var(--mnb-surface)}.bg-panel{background:var(--mnb-panel)}.bg-elev{background:var(--mnb-elev)}
  .bg-gradient{background-image:var(--mnb-grad-1);color:white}

  /* Icon link */
  .icon-link { display:inline-flex; gap:.5em; align-items:center; color:var(--mnb-primary); }
  .icon-link:hover { color: var(--mnb-primary-600); transform: translateY(-1px); }

  /* Stacks (vertical rhythm) */
  .stack > * + * { margin-top: var(--space-4); }
  .cluster { display:flex; flex-wrap:wrap; gap:var(--space-3); align-items:center; }

  /* Ratio */
  .ratio { position:relative; width:100%; }
  .ratio::before { content:""; display:block; padding-top: var(--ratio, 56.25%); }
  .ratio > * { position:absolute; inset:0; }

  /* Stretched link */
  .stretched-link { position:relative; }
  .stretched-link::after { content:""; position:absolute; inset:0; }

  /* Clearfix */
  .clearfix::after { content:""; display:block; clear:both; }

  /* Vertical align */
  .align-middle{vertical-align:middle}

  /* Overflow & Object fit */
  .of-hidden{overflow:hidden}.object-cover{object-fit:cover}

  /* Opacity */
  .opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}

  /* Breakpoints */
  @media (min-width: 640px) {
    .sm\\:grid-2{grid-template-columns:repeat(2, minmax(0,1fr));}
    .sm\\:d-grid{display:grid}
  }
  @media (min-width: 768px) {
    .md\\:grid-2{grid-template-columns:repeat(2, minmax(0,1fr));}
    .md\\:grid-3{grid-template-columns:repeat(3, minmax(0,1fr));}
    .md\\:d-flex{display:flex}
  }
  @media (min-width: 1024px) {
    .lg\\:grid-3{grid-template-columns:repeat(3, minmax(0,1fr));}
    .lg\\:grid-4{grid-template-columns:repeat(4, minmax(0,1fr));}
    .lg\\:d-grid{display:grid}
  }
}



/* --------------------------------------
   5) Components (buttons, cards, nav, forms, badges)
-------------------------------------- */
@layer components {
  /* Buttons */
  .btn {
    --btn-bg: var(--mnb-primary);
    --btn-fg: #fff;
    --btn-bg-hover: var(--mnb-primary-600);
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.7rem 1rem; border-radius: var(--radius);
    background: var(--btn-bg); color: var(--btn-fg);
    border: 1px solid rgba(255,255,255,.09);
    box-shadow: var(--shadow-sm);
    transition: transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease), background var(--speed) var(--ease);
    will-change: transform;
  }
  .btn:hover { transform: translateY(-1px); box-shadow: var(--shadow); background: var(--btn-bg-hover); }
  .btn:active { transform: translateY(0); box-shadow: var(--shadow-sm); }
  .btn.secondary { --btn-bg: var(--mnb-secondary); }
  .btn.ghost { --btn-bg: transparent; --btn-fg: var(--mnb-text); border-color: var(--mnb-border); }
  .btn.block { display:flex; justify-content:center; width:100%; }

  /* Badges */
  .badge { display:inline-block; padding:.25rem .5rem; border-radius:999px; background: rgba(99,102,241,.15); color:#c7d2fe; border:1px solid rgba(99,102,241,.25); }

  /* Card */
  .card { position:relative; border-radius: var(--radius-xl); background: linear-gradient(180deg, rgba(17,24,39,.85), rgba(17,24,39,.7)); border:1px solid rgba(148,163,184,.15); box-shadow: var(--shadow); overflow:hidden; }
  .card .card-body { padding: var(--space-6); }
  .card.hover:hover { transform: translateY(-3px); transition: transform var(--speed) var(--ease); }

  /* Navbar */
  .navbar { position:sticky; top:0; z-index:var(--z-5); backdrop-filter: blur(10px); background: rgba(11,14,20,.6); border-bottom:1px solid rgba(148,163,184,.15); }
  .navbar .inner { display:flex; align-items:center; justify-content:space-between; padding: .75rem 0; }

  /* Footer */
  .footer { margin-top: var(--space-16); padding: var(--space-8) 0; border-top:1px solid var(--mnb-border); background: rgba(11,14,20,.6); }

  /* Forms */
  .form-control { width:100%; background: var(--mnb-panel); color:var(--mnb-text); border:1px solid rgba(148,163,184,.2); border-radius: var(--radius); padding:.7rem .9rem; transition: border-color var(--speed) var(--ease), box-shadow var(--speed) var(--ease); }
  .form-control::placeholder { color: var(--mnb-muted); }
  .form-control:focus { border-color: var(--mnb-ring); box-shadow: 0 0 0 3px rgba(147,197,253,.25); outline: none; }
  .input-group { display:flex; align-items:center; border:1px solid rgba(148,163,184,.2); border-radius: var(--radius); overflow:hidden; }
  .input-group > .addon { padding:.7rem .9rem; background: var(--mnb-elev); border-right:1px solid rgba(148,163,184,.2); }
  .check { display:flex; gap:.5rem; align-items:center; }
  .check input[type="checkbox"], .check input[type="radio"] { width:1.05rem; height:1.05rem; accent-color: var(--mnb-primary); }

  /* Tooltips (pure CSS) */
  .tooltip { position:relative; cursor:help; }
  .tooltip[data-tip]::after {
    content: attr(data-tip); position:absolute; inset:auto auto 100% 50%; transform: translate(-50%, -.4rem);
    background: #0b1220; color: #e5e7eb; padding:.35rem .5rem; border-radius:.35rem; border:1px solid rgba(148,163,184,.25);
    opacity:0; pointer-events:none; transition: opacity var(--speed) var(--ease);
    white-space:nowrap; font-size: var(--step--1);
  }
  .tooltip:hover::after { opacity:1; }

  /* Progress */
  .progress { width:100%; height:.5rem; background: rgba(148,163,184,.15); border-radius:999px; overflow:hidden; }
  .progress > .bar { height:100%; background: var(--mnb-grad-1); width:0%; transition: width var(--speed-slow) var(--ease); }

  /* Toasts */
  .toast { position:fixed; right:1rem; bottom:1rem; z-index:var(--z-max); display:grid; gap:.75rem; }
  .toast .item { background: rgba(17,24,39,.85); border:1px solid rgba(148,163,184,.2); padding:.75rem 1rem; border-radius: var(--radius); box-shadow: var(--shadow); }

  /* Spinners */
  .spinner { width:1.25rem; height:1.25rem; border-radius:50%; border:.18rem solid rgba(255,255,255,.18); border-top-color:#fff; animation: spin 1s linear infinite; }

  /* Placeholder skeleton */
  .skeleton { background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.08), rgba(255,255,255,.04)); background-size: 200% 100%; animation: shimmer 1.5s infinite; border-radius: .5rem; }
}



/* --------------------------------------
   6) Motion & Animations
-------------------------------------- */
@layer motion {
  @keyframes spin { to { transform: rotate(360deg); } }
  @keyframes float { 0%,100%{ transform: translateY(0);} 50%{ transform: translateY(-6px);} }
  @keyframes pulseSoft { 0%,100%{ opacity: .85 } 50%{ opacity: 1 } }
  @keyframes shimmer { 0%{ background-position: -200% 0 } 100%{ background-position: 200% 0 } }

  .float { animation: float 5s var(--ease) infinite; will-change: transform; }
  .pulse-soft { animation: pulseSoft 2.8s ease-in-out infinite; }
  .spin { animation: spin 1.2s linear infinite; }

  /* Reduced motion */
  @media (prefers-reduced-motion: reduce) {
    * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
  }
}



/* --------------------------------------
   7) Pages (existing page CSS appended below)
-------------------------------------- */
@layer pages {
  /* Page-specific CSS is appended programmatically to preserve behavior.
     Consider migrating repeated patterns to utilities/components above. */
}

/* =====================================================
   mnb-sections.css — FULL responsive build
   Combines your base section styles + mobile/medium tweaks.
   Safe to drop-in as a replacement.
===================================================== */

/* ABOUT — base layout */
.mnb-about--clean{
  position:relative;overflow:hidden;border-top:var(--mnb-border-strong);
  background:
    radial-gradient(1100px 520px at 0% 0%, rgba(44,76,117,.05), transparent 60%),
    radial-gradient(900px 520px at 100% 100%, rgba(106,189,69,.08), transparent 60%),
    linear-gradient(180deg,#ffffff 0%, #f7fbff 100%);
}


.mnb-about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--mnb-s-7);align-items:center}


.mnb-about-grid--icons{ gap:clamp(var(--mnb-s-6), 5vw, var(--mnb-s-8)); }


.mnb-about-eyebrow{display:inline-flex;align-items:center;gap:.5rem;color:var(--mnb-green);font-weight:800;letter-spacing:.06em;text-transform:uppercase;font-size:.9rem}


.mnb-about-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--mnb-green);box-shadow:0 0 0 6px rgba(106,189,69,.16)}


.mnb-about-title{margin:.35rem 0 .6rem;font-size:clamp(2rem, 3.2vw, 2.6rem);line-height:1.12;color:var(--mnb-navy)}


.mnb-about-lead{color:var(--mnb-muted);max-width:62ch;font-size:clamp(1.05rem, 1.2vw, 1.15rem)}


.mnb-about-list{margin:1rem 0 0;padding:0;list-style:none}


.mnb-about-list li{display:flex;gap:.6rem;align-items:flex-start;margin:.55rem 0;color:var(--mnb-ink)}


.mnb-about-list i{color:var(--mnb-green);margin-top:.2rem}


.mnb-about-copy{margin-top:var(--mnb-s-5)}


.mnb-about-copy p{margin:.6rem 0;color:var(--mnb-ink)}


.mnb-about-ctas{margin-top:var(--mnb-s-4); display:flex; gap:.75rem; flex-wrap:wrap}


.mnb-about-right{
  position:relative; display:grid; gap:var(--mnb-s-4);
  background:
    radial-gradient(900px 420px at 110% -10%, rgba(0,207,255,.10), transparent 60%),
    radial-gradient(900px 480px at -10% 110%, rgba(106,189,69,.12), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
  border:1px solid rgba(0,0,0,.06); border-radius:22px;
  padding:clamp(1.1rem, 2.8vw, 1.75rem);
  box-shadow: 0 14px 42px rgba(18,32,54,.10), inset 0 1px 0 rgba(255,255,255,.55);
}



/* ABOUT — premium motion & hovers */
:root{
  --about-reveal-y: 22px;
  --about-reveal-ms: 640ms;
  --about-shine-ms: 1200ms;
}


.mnb-about--clean::before,
.mnb-about--clean::after{
  content:""; position:absolute; inset:auto auto -40px -60px; width:440px; height:440px;
  background:
    radial-gradient(closest-side, rgba(0,207,255,.14), transparent 70%),
    conic-gradient(from 210deg at 50% 50%, rgba(106,189,69,.20), rgba(44,76,117,.18), rgba(0,207,255,.20), rgba(106,189,69,.20));
  filter: blur(18px); opacity:.55; border-radius:36% 64% 49% 51% / 44% 36% 64% 56%;
  pointer-events:none; z-index:0; transform:rotate(-6deg);
}


.mnb-about--clean::after{ inset:-60px -60px auto auto; transform:rotate(12deg); width:380px; height:380px; opacity:.38; }



.mnb-about-eyebrow .dot{position:relative; isolation:isolate;}


.mnb-about-eyebrow .dot::after{
  content:""; position:absolute; inset:-6px; border-radius:inherit;
  background:radial-gradient(closest-side, rgba(106,189,69,.35), transparent 70%);
  animation: about-dot-pulse 2s ease-out infinite; z-index:-1;
}


@keyframes about-dot-pulse{ 0%{transform:scale(.6);opacity:.6} 70%,100%{transform:scale(1.3);opacity:0} }



/* KPIs */
.mnb-kpis{display:grid; grid-template-columns:repeat(3,1fr); gap:.9rem}


.mnb-kpi{
  position:relative; overflow:hidden;
  display:grid; place-items:center; text-align:center; padding:1rem .75rem;
  border-radius:16px;
  background:
    linear-gradient(#fff,#fff) padding-box,
    conic-gradient(from var(--kpi-angle, 0deg),
      rgba(106,189,69,.45), rgba(0,207,255,.45), rgba(44,76,117,.45), rgba(106,189,69,.45)) border-box;
  border:1.8px solid transparent; box-shadow:var(--mnb-shadow);
  transform-style:preserve-3d; will-change:transform, box-shadow;
}


.mnb-kpi i{font-size:1.35rem; color:var(--mnb-green); filter:drop-shadow(0 1px 1px rgba(0,0,0,.15))}


.mnb-kpi strong{display:block; margin-top:.35rem; font-size:1.15rem; color:var(--mnb-navy)}


.mnb-kpi small{color:var(--mnb-muted); font-weight:700; letter-spacing:.04em}


.mnb-kpi::after{
  content:""; position:absolute; inset:-20%;
  background:linear-gradient(110deg, transparent 40%, rgba(255,255,255,.45) 50%, transparent 60%);
  transform:translateX(-120%) rotate(8deg);
  opacity:.0; pointer-events:none;
}


.mnb-kpi:hover{
  transform:translateY(-6px) rotateX(1.2deg) rotateY(-1.2deg);
  box-shadow:0 18px 44px rgba(0,0,0,.16);
  --kpi-angle: 360deg;
}


.mnb-kpi:hover::after{ animation: about-shine var(--about-shine-ms) ease-out forwards; }


@keyframes about-shine{ to{ transform:translateX(120%) rotate(8deg); opacity:.85; } }



/* Icon tiles */
.mnb-icon-tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:.9rem }


.mnb-icon-tile{
  position:relative; overflow:hidden; display:grid; place-items:center; text-align:center;
  padding:1.1rem .8rem; border-radius:16px; color:var(--mnb-navy);
  border:1.6px solid transparent;
  box-shadow:0 12px 28px rgba(0,0,0,.10), inset 0 1px 0 rgba(255,255,255,.65);
  background:
    linear-gradient(#fff,#fff) padding-box,
    conic-gradient(from var(--tile-angle, 90deg),
      rgba(106,189,69,.4), rgba(0,207,255,.4), rgba(44,76,117,.4), rgba(106,189,69,.4)) border-box;
  transform-style:preserve-3d; transition:transform .18s var(--mnb-ease), box-shadow .18s var(--mnb-ease), filter .18s var(--mnb-ease);
}


.mnb-icon-tile i{font-size:1.3rem; filter:drop-shadow(0 1px 1px rgba(0,0,0,.2)); transition:transform .18s var(--mnb-ease), filter .18s var(--mnb-ease)}


.mnb-icon-tile span{margin-top:.4rem; font-weight:800; font-size:.92rem}


.mnb-icon-tile:hover{ transform:translateY(-6px) scale(1.02) rotate(.2deg); box-shadow:var(--mnb-shadow-2); --tile-angle: 450deg; }


.mnb-icon-tile:hover i{ transform:translateZ(18px) scale(1.06); filter:drop-shadow(0 3px 6px rgba(0,0,0,.25)) }



/* Reveal on scroll */
.mnb-about-left > *, .mnb-kpi, .mnb-icon-tile{ opacity:0; transform:translateY(var(--about-reveal-y)) scale(.98); }


.mnb-reveal-in{ animation: about-reveal var(--about-reveal-ms) var(--mnb-ease) forwards; }


@keyframes about-reveal{ to{ opacity:1; transform:none } }



/* Trust ribbon */
.mnb-about-note{
  display:flex; align-items:center; gap:.6rem; padding:.8rem 1rem;
  border-radius:999px;
  background:linear-gradient(#fff,#fff) padding-box, var(--mnb-gradient) border-box;
  border:2px solid transparent; color:var(--mnb-navy); font-weight:800;
}


.mnb-about-note i{color:var(--mnb-green)}



/* ALT FEATURE */
.mnb-alt{position:relative;background:
  radial-gradient(900px 360px at 0% 0%, rgba(44,76,117,.06), transparent 60%),
  radial-gradient(900px 360px at 100% 100%, rgba(106,189,69,.08), transparent 60%),#f4f8fb;border-top:var(--mnb-border-strong)}


.mnb-grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:var(--mnb-s-6);align-items:center}


.mnb-lead{color:var(--mnb-muted);max-width:56ch;font-size:var(--mnb-fs-lead)}


.mnb-feature-icons{
  display:grid; grid-template-columns:repeat(3,1fr); gap:.8rem;
  background:linear-gradient(180deg,#fff,#f9fbff); border:1px solid rgba(0,0,0,.06);
  border-radius:18px; padding:1rem; box-shadow:var(--mnb-shadow);
}


.mnb-feature-icons .tile{
  display:grid; place-items:center; gap:.35rem; text-align:center; padding:1rem .5rem;
  border-radius:14px; background:linear-gradient(#fff,#fff) padding-box, var(--mnb-gradient) border-box; border:1.5px solid transparent;
  font-weight:800; color:var(--mnb-navy);
}


.mnb-feature-icons .tile i{font-size:1.2rem; color:var(--mnb-green)}


.mnb-feature-icons .tile b{font-size:.9rem}




/* ===== Services (mnb-service namespace) ===== */
.mnb-service-section{
  position: relative;
  padding: clamp(20px,2vw,28px) 0 clamp(70px,6vw,110px);
  background: var(--mnb-surface,#fff);
  border-top: 1px solid var(--mnb-line,#E8EEF6);
  isolation: isolate;
}


.mnb-service-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(700px 340px at 12% 18%, color-mix(in oklab, var(--mnb-aqua) 16%, transparent) 0%, transparent 60%),
    radial-gradient(800px 360px at 88% 80%, color-mix(in oklab, var(--mnb-green) 22%, transparent) 0%, transparent 62%),
    linear-gradient(180deg, #fff 0%, color-mix(in oklab, var(--mnb-navy) 4%, #fff) 100%);
  mask:
    radial-gradient(60% 90% at 50% 10%, #000 70%, transparent 72%)
    top/100% 100% no-repeat;
  opacity:.9;
}



/* Container */
.mnb-service-container{ width:min(1140px,92vw); margin-inline:auto; position:relative; z-index:1; }



/* Header */
.mnb-service-head{
  display:flex; align-items:end; justify-content:space-between; gap:18px;
  background: linear-gradient(135deg, color-mix(in oklab, var(--mnb-aqua) 8%, #fff), color-mix(in oklab, var(--mnb-green) 8%, #fff));
  border:1px solid var(--mnb-line);
  border-radius: 22px;
  padding: clamp(16px,2.4vw,24px);
  box-shadow: 0 12px 28px rgba(18,32,54,.06);
  margin-bottom: clamp(18px,2vw,26px);
}


.mnb-service-eyebrow{
  display:inline-flex; align-items:center; gap:.5rem; font-weight:700; color:var(--mnb-navy);
}


.mnb-service-eyebrow .dot{
  width:9px; height:9px; border-radius:999px; display:inline-block;
  background: linear-gradient(90deg, var(--mnb-aqua), var(--mnb-green));
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--mnb-aqua) 15%, transparent),
              0 0 16px color-mix(in oklab, var(--mnb-aqua) 40%, transparent);
}


.mnb-service-title{
  margin:.25rem 0 0 0;
  font-size: clamp(1.35rem, 2.2vw, 2.1rem);
  line-height:1.15; font-weight:900; color: var(--mnb-navy);
}


.mnb-service-title .accent{
  background: linear-gradient(90deg, var(--mnb-aqua), var(--mnb-green));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}



/* CTA */
.mnb-service-btn{ display:inline-flex; align-items:center; gap:.55rem; font-weight:800; text-decoration:none; }


.mnb-service-btn-outline{
  color: var(--mnb-navy);
  background:#fff;
  border:1px solid var(--mnb-line);
  padding:.7rem 1rem; border-radius:14px;
  transition: background .2s ease, transform .15s ease, border-color .2s;
}


.mnb-service-btn-outline:hover{ transform: translateY(-1px); background: color-mix(in oklab, var(--mnb-aqua) 6%, #fff); border-color: color-mix(in oklab, var(--mnb-aqua) 25%, var(--mnb-line)); }



/* Grid */
.mnb-service-grid{
  margin-top: clamp(26px,3vw,42px);
  display:grid; gap: clamp(14px,1.6vw,22px);
  grid-template-columns: repeat(4, minmax(0,1fr));
}


@media (max-width:1100px){ .mnb-service-grid{ grid-template-columns:repeat(3,1fr);} }


@media (max-width:820px){  .mnb-service-grid{ grid-template-columns:repeat(2,1fr);} }


@media (max-width:540px){  .mnb-service-grid{ grid-template-columns:1fr;} }



/* Card (tab-top + hex badge) */
.mnb-service-card{
  position:relative; background:#fff;
  border:1px solid var(--mnb-line);
  border-radius: 22px;
  box-shadow: 0 12px 26px rgba(18,32,54,.06);
  padding: 70px 18px 20px;      /* space for badge */
  min-height: 220px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}


.mnb-service-card::before{
  /* soft tab cap */
  content:""; position:absolute; left:0; right:0; top:0; height:56px;
  border-radius: 22px 22px 0 0;
  background: linear-gradient(180deg, #fff, #f7fbff);
}


.mnb-service-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 44px rgba(18,32,54,.10);
  border-color: color-mix(in oklab, var(--mnb-aqua) 25%, var(--mnb-line));
}



/* Badge */
.mnb-service-badge{
  position:absolute; left:50%; top:-16px; transform:translateX(-50%);
  width:60px; height:60px; display:grid; place-items:center;
  color:#fff; font-size:22px;
  background: linear-gradient(135deg, color-mix(in oklab, var(--mnb-navy) 40%, #6b7cff), color-mix(in oklab, var(--mnb-aqua) 60%, var(--mnb-green) 30%));
  box-shadow: 0 12px 24px color-mix(in oklab, var(--mnb-navy) 25%, transparent);
  clip-path: polygon(25% 6%, 75% 6%, 100% 50%, 75% 94%, 25% 94%, 0% 50%); /* hex */
}



/* Card text */
.mnb-service-card-title{
  margin: 6px 0 8px; text-align:center;
  font-size: 1.05rem; font-weight: 900; color: var(--mnb-ink);
}


.mnb-service-card-text{
  margin:0; text-align:center; color: var(--mnb-muted); line-height:1.55; font-size:.96rem;
}



/* Nice focus for accessibility */
.mnb-service-card:focus-within,
.mnb-service-card:focus-visible{ outline:3px solid color-mix(in oklab, var(--mnb-aqua) 60%, transparent); outline-offset:3px; }





/* Section wrapper */
.mnb-why-chooseus{
  position:relative;
  background:linear-gradient(135deg,#f9fbfd 0%,#f0f4ff 100%);
  padding:clamp(56px,7vw,92px) 0;
  overflow:hidden;
}



/* Soft gradient blobs */
.mnb-why-chooseus::before,
.mnb-why-chooseus::after{
  content:"";
  position:absolute;
  width:420px; height:420px;
  border-radius:50%;
  filter:blur(120px);
  opacity:.35;
  z-index:0;
}


.mnb-why-chooseus::before{ top:-120px; left:-120px; background:var(--mnb-green); }


.mnb-why-chooseus::after{ bottom:-160px; right:-160px; background:var(--mnb-aqua); }



.mnb-why-chooseus__container{ position:relative; z-index:1; }



/* Text */
.mnb-why-chooseus__kicker{
  font-weight:700; letter-spacing:.02em; color:var(--mnb-muted);
}


.mnb-why-chooseus__title{
  font-size:clamp(1.6rem,2.3vw,2.3rem);
  line-height:1.25; margin:.4rem 0 1rem; color:var(--mnb-navy);
}


.mnb-why-chooseus__accent{ color:var(--mnb-green); }


.mnb-why-chooseus__lead{
  font-size:clamp(1rem,1.1vw,1.125rem);
  color:var(--mnb-ink); opacity:.9; max-width:720px;
}



/* Features grid */
.mnb-why-chooseus__grid{
  margin-top:2rem;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.5rem;
}


.mnb-why-chooseus__feature{
  display:flex; gap:1rem; align-items:flex-start;
  background:#fff; border:1px solid var(--mnb-line); border-radius:14px;
  padding:1.25rem 1.2rem; box-shadow:var(--mnb-shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}


.mnb-why-chooseus__feature:hover{ transform:translateY(-6px); box-shadow:var(--mnb-shadow-2); }


.mnb-why-chooseus__feature i{
  flex-shrink:0; font-size:1.5rem; color:var(--mnb-green);
  background:rgba(106,189,69,.1); border-radius:50%; padding:.7rem;
}


.mnb-why-chooseus__feature h3{ font-size:1.1rem; margin:0 0 .4rem; color:var(--mnb-navy); }


.mnb-why-chooseus__feature p{ margin:0; font-size:.95rem; color:var(--mnb-ink); opacity:.85; line-height:1.45; }



/* WhatsApp button position (scoped) */
.mnb-why-chooseus__whatsapp{
  position:absolute; right:clamp(12px,3vw,24px); bottom:clamp(12px,3vw,24px);
}



/* ===== Staggered fade-in on scroll ===== */
.mnb-why-chooseus__reveal{
  --delay-step: 90ms;      /* base step for stagger */
  opacity:0; transform:translateY(18px);
  will-change: transform, opacity;
  animation: none;
}


.mnb-why-chooseus__reveal.is-in{
  animation: mnb-why-chooseus-fade 620ms cubic-bezier(.22,.61,.36,1) forwards;
  /* stagger by index (set inline as --i on each card) */
  animation-delay: calc(var(--i, -1) * var(--delay-step));
}


/* Title & lead get fixed positions in the sequence */
.mnb-why-chooseus__title.mnb-why-chooseus__reveal.is-in{ animation-delay: 0ms; }


.mnb-why-chooseus__lead.mnb-why-chooseus__reveal.is-in{ animation-delay: 120ms; }



@keyframes mnb-why-chooseus-fade{
  to{ opacity:1; transform:translateY(0); }
}



/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .mnb-why-chooseus__reveal{ opacity:1; transform:none; animation:none !important; }
  .mnb-why-chooseus__feature{ transition:none; }
}







/* ======================================================
   TECHNOLOGIES — Animated Background + Parallax Tilt
   Brand vars expected: --mnb-green, --mnb-navy, --mnb-aqua, --mnb-ink, --mnb-muted
====================================================== */

/* Section shell: aurora beams + corner energy + shimmer */
.mnb-technologies-hub{
  --hub-size: clamp(172px, 23vw, 260px);
  --pill-delay: 70ms;

  position: relative;
  padding: clamp(56px, 8vw, 100px) 0;
  color: #fff;
  overflow: clip;
  isolation: isolate;

  /* Base gradients */
  background: linear-gradient(125deg, rgba(255, 255, 255, .06) 0%, transparent 48%), linear-gradient(-120deg, rgba(255, 255, 255, .05) 0%, transparent 44%), radial-gradient(900px 520px at 15% -15%,
 color-mix(in oklab, var(--mnb-aqua) 18%, transparent), transparent 70%), radial-gradient(1000px 640px at 90% 120%,
 color-mix(in oklab, var(--mnb-green) 22%, transparent), transparent 70%), linear-gradient(180deg,
 color-mix(in oklab, var(--mnb-navy) 92%, #4c895d 6%) 0%, #62b052 100%);

  border-top: 1px solid color-mix(in oklab, var(--mnb-navy) 35%, transparent);
}



/* Vignette + noise (static) */
.mnb-technologies-hub::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(110% 150% at 50% 40%, transparent 70%, rgba(0,0,0,.40) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}



/* Animated shimmer (gentle) */
.mnb-technologies-hub::after{
  content:""; position:absolute; inset:-10%; z-index:0; pointer-events:none;
  background:
    linear-gradient(100deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.06) 40%, rgba(255,255,255,0) 70%) 0 0 / 180% 100% no-repeat,
    conic-gradient(from 0deg at 50% 40%, transparent 0 22%, color-mix(in oklab, var(--mnb-aqua) 10%, transparent) 24%, transparent 58%, color-mix(in oklab, var(--mnb-green) 12%, transparent) 60%, transparent 100%);
  opacity:.9; filter: blur(2px) saturate(1.02);
  will-change: background-position, transform;
  animation: mnb-tech-shimmer-pan 26s cubic-bezier(.25,.1,.25,1) infinite,
             mnb-tech-conic-rotate 120s linear infinite;
}



/* NEW: Soft grid lines layer (separate node for crisp masking) */
.mnb-technologies-grid{
  position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.14;
  background:
    /* diagonal micro grid */
    repeating-linear-gradient( 0deg, rgba(255,255,255,.10) 0 1px, transparent 1px 32px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.08) 0 1px, transparent 1px 32px);
  /* fade edges so grid doesn’t clash with content */
  -webkit-mask-image: radial-gradient(120% 90% at 50% 45%, black 60%, transparent 100%);
          mask-image: radial-gradient(120% 90% at 50% 45%, black 60%, transparent 100%);
  transform: translateZ(0);
  animation: mnb-tech-grid-sway 40s ease-in-out infinite alternate;
}



/* Container */
.mnb-technologies-container{ width:min(1200px, 94%); margin:0 auto; position:relative; z-index:1; }



/* Header */
.mnb-technologies-head{ text-align:center; max-width:900px; margin:0 auto clamp(24px, 3.6vw, 34px); }


.mnb-technologies-eyebrow{
  display:inline-flex; gap:.55rem; align-items:center;
  padding:.46rem .9rem; border-radius:999px; font-weight:900; letter-spacing:.06em; text-transform:uppercase;
  background:linear-gradient(180deg, color-mix(in oklab, #fff 16%, transparent), color-mix(in oklab, #fff 8%, transparent));
  border:1px solid color-mix(in oklab, #fff 28%, transparent);
  box-shadow:inset 0 1px 0 color-mix(in oklab, #fff 34%, transparent);
  font-size:.86rem;
}


.mnb-technologies-title{
  margin:.7rem 0 .45rem; font-weight:900; line-height:1.06;
  font-size:clamp(1.9rem,3.6vw,2.75rem); color:#fff;
  text-shadow:0 14px 40px rgba(0,0,0,.38);
}


.mnb-technologies-sub{ margin:0; color:color-mix(in oklab, #fff 88%, var(--mnb-aqua) 12%); }



/* Grid: columns + center */
.mnb-technologies-wrap{
  position:relative;
  display:grid;
  grid-template-columns: 1fr var(--hub-size) 1fr;
  align-items:center;
  gap: clamp(14px, 2.4vw, 32px);
  margin-top: clamp(20px, 3.2vw, 30px);
}



/* Column wrappers with titles */
.mnb-technologies-colwrap{ display:flex; flex-direction:column; gap:14px; }


.mnb-technologies-coltitle{
  margin:0; font-size: .95rem; letter-spacing:.14em; text-transform:uppercase; opacity:.9;
  display:inline-flex; align-items:center; gap:.6rem;
  color: color-mix(in oklab, #fff 86%, var(--mnb-muted) 14%);
}


.mnb-technologies-coltitle i{ font-size:.95rem; opacity:.9 }



/* ---- Parallax tilt stack ---- */
.mnb-technologies-center{
  position:relative; width:var(--hub-size); height:var(--hub-size); margin-inline:auto;
  perspective: 900px;          /* camera distance */
  perspective-origin: 50% 45%;
}


.mnb-technologies-center-persp{
  position:absolute; inset:0;
  transform-style: preserve-3d;
  will-change: transform, filter;
  transition: transform .18s ease, filter .18s ease;
}



/* Center ring & core */
.mnb-technologies-center-ring{
  position:absolute; inset:0; border-radius:50%;
  border:2px dashed color-mix(in oklab, var(--mnb-aqua) 46%, #fff 8%);
  background:
    radial-gradient(closest-side, color-mix(in oklab, #fff 7%, transparent), transparent 60%),
    radial-gradient(closest-side, color-mix(in oklab, var(--mnb-green) 16%, transparent) 0 30%, transparent 65%);
  animation: mnb-technologies-spin 52s linear infinite;
  filter: drop-shadow(0 14px 40px rgba(0,0,0,.35));
  transform: translateZ(25px);
}


.mnb-technologies-center-core{
  position:absolute; inset:12%; border-radius:50%;
  background:
    radial-gradient(120% 120% at 30% 30%, #fff 0 55%, #f4f7fb 60%),
    #fff;
  display:grid; place-items:center;
  box-shadow:
    0 12px 34px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.95),
    inset 0 -12px 26px rgba(0,0,0,.04);
  transform: translateZ(60px);
}


.mnb-technologies-logo{ width:72%; height:auto; display:block; }


.mnb-technologies-core-glow{
  position:absolute; inset:-8%; border-radius:50%;
  background: radial-gradient(60% 60% at 50% 50%, color-mix(in oklab, var(--mnb-aqua) 18%, transparent), transparent 70%);
  filter: blur(16px); opacity:.6; z-index:-1;
}


/* specular shine that reacts to tilt */
.mnb-technologies-core-shine{
  position:absolute; inset:0; border-radius:50%;
  background:
    radial-gradient(120% 120% at calc(50% + var(--mx,0)*18%) calc(35% + var(--my,0)*18%),
      rgba(255,255,255,.50), transparent 55%);
  mix-blend-mode: screen; pointer-events:none; transition: background-position .12s ease-out;
}



/* Orbiting dots (parallax layers) */
.mnb-technologies-orb{
  position:absolute; inset:0; margin:auto; width:10px; height:10px; border-radius:50%;
  background: color-mix(in oklab, var(--mnb-aqua) 60%, #fff 10%);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--mnb-aqua) 18%, transparent);
  transform: translateZ(40px);
}


.mnb-technologies-orb.o1{ animation: mnb-technologies-orbit 14s linear infinite; translate: calc(var(--hub-size)/2) 0; }


.mnb-technologies-orb.o2{ animation: mnb-technologies-orbit 18s linear infinite reverse; translate: calc(var(--hub-size)/2.4) 0; background: color-mix(in oklab, var(--mnb-green) 60%, #fff 10%); box-shadow: 0 0 0 4px color-mix(in oklab, var(--mnb-green) 18%, transparent); transform: translateZ(20px); }


.mnb-technologies-orb.o3{ animation: mnb-technologies-orbit 22s linear infinite; translate: calc(var(--hub-size)/3.1) 0; width:8px; height:8px; opacity:.9; transform: translateZ(10px); }



/* Columns */
.mnb-technologies-col{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap: clamp(12px, 1.9vw, 18px);
  position:relative;
}


.mnb-technologies-col--left{  align-items:flex-end; }


.mnb-technologies-col--right{ align-items:flex-start; }



/* Side-based theming */
.mnb-technologies-col--left{
  --side-bg: var(--mnb-green);
  --side-fg: #fff;
  --side-ink: var(--mnb-navy);
}


.mnb-technologies-col--right{
  --side-bg: var(--mnb-navy);
  --side-fg: #fff;
  --side-ink: #fff;
}



/* Pills */
.mnb-technologies-pill{
  --r: 999px;
  position:relative;
  display:inline-flex; align-items:center; gap:.66rem;
  padding:.78rem 1.08rem;
  border-radius: var(--r);
  background: linear-gradient(180deg, color-mix(in oklab, var(--side-bg) 92%, black 6%), var(--side-bg));
  color: var(--side-fg);
  border:1px solid color-mix(in oklab, var(--side-bg) 42%, #fff 10%);
  box-shadow: 0 14px 28px color-mix(in oklab, #000 26%, transparent), inset 0 1px 0 color-mix(in oklab, #fff 14%, transparent);
  font-weight:800; letter-spacing:.01em;
  transition: transform .28s cubic-bezier(.22,.61,.36,1), box-shadow .28s cubic-bezier(.22,.61,.36,1), filter .28s, background-position .9s cubic-bezier(.22,.61,.36,1);
  overflow:hidden; cursor:default;
  opacity:0; translate: 0 8px;
  animation: mnb-technologies-reveal .6s cubic-bezier(.22,.61,.36,1) both;
  /* Shine */
  background-image: linear-gradient(120deg, transparent 0%, transparent 35%, rgba(255,255,255,.35) 50%, transparent 65%, transparent 100%);
  background-size: 220% 100%; background-repeat:no-repeat;
}


.mnb-technologies-pill:hover{
  transform: translateY(-4px);
  filter: brightness(1.04);
  box-shadow: 0 18px 36px color-mix(in oklab, #000 34%, transparent);
  background-position: 120% 0;
}


.mnb-technologies-pill:focus-visible{
  outline:3px solid color-mix(in oklab, var(--side-bg) 35%, #fff 10%); outline-offset:3px;
}



/* Icon/monogram */
.mnb-technologies-pill i,
.mnb-technologies-mono{
  display:grid; place-items:center;
  width:32px; height:32px; border-radius:50%;
  background:#fff; color: var(--mnb-navy);
  font-size:.92rem; font-weight:900;
  box-shadow:0 4px 12px rgba(0,0,0,.18), inset 0 1px 0 rgba(0,0,0,.06);
}



/* Connectors */
.mnb-technologies-pill::after{
  content:""; position:absolute; top:50%; translate:0 -50%; height:2px;
  width: clamp(26px, 6vw, 60px);
  background: linear-gradient(90deg, color-mix(in oklab, var(--side-bg) 0%, transparent), color-mix(in oklab, var(--side-bg) 70%, #fff 10%));
}


.mnb-technologies-pill::before{
  content:""; position:absolute; top:50%; translate:0 -50%;
  width:10px; height:10px; border-radius:50%;
  background: var(--side-bg);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--side-bg) 20%, transparent);
}


.mnb-technologies-col--left  .mnb-technologies-pill::after{ right:-32px; }


.mnb-technologies-col--right .mnb-technologies-pill::after{ left:-32px; }


.mnb-technologies-col--left  .mnb-technologies-pill::before{ right: calc(-32px - clamp(26px,6vw,60px)); }


.mnb-technologies-col--right .mnb-technologies-pill::before{ left:  calc(-32px - clamp(26px,6vw,60px)); }



/* Animations */
@keyframes mnb-technologies-spin{ to{ rotate:360deg } }


@keyframes mnb-technologies-orbit{ to{ rotate:360deg } }


@keyframes mnb-technologies-reveal{
  from{ opacity:0; translate:0 10px; filter: blur(.5px) saturate(.9); }
  to  { opacity:1; translate:0 0;   filter: blur(0)    saturate(1); }
}


@keyframes mnb-tech-shimmer-pan{
  0%   { background-position: -120% 0, center; }
  50%  { background-position:  10% 0, center; }
  100% { background-position: 120% 0, center; }
}


@keyframes mnb-tech-conic-rotate{ to{ transform: rotate(360deg); } }


@keyframes mnb-tech-grid-sway{
  0%   { transform: translateY(-1.5%) rotate(0.001deg); }
  100% { transform: translateY(1.5%)  rotate(0.001deg); }
}



/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .mnb-technologies-hub::after,
  .mnb-technologies-grid,
  .mnb-technologies-center-ring,
  .mnb-technologies-orb,
  .mnb-technologies-pill{ animation: none !important; }
  .mnb-technologies-pill{ opacity:1; translate:0 }
}



/* Responsive */
@media (max-width: 1080px){
  .mnb-technologies-coltitle{ font-size:.9rem; letter-spacing:.12em; }
}


@media (max-width: 960px){
  .mnb-technologies-wrap{ grid-template-columns:1fr; gap:22px; }
  .mnb-technologies-center{ order:-1; margin-inline:auto; }
  .mnb-technologies-col{ align-items:stretch }
  .mnb-technologies-pill::after,
  .mnb-technologies-pill::before{ display:none } /* hide arms on small screens */
  .mnb-technologies-colwrap{ gap:10px }
}


@media (max-width: 520px){
  .mnb-technologies-title{ font-size:clamp(1.6rem, 8vw, 2.1rem); }
  .mnb-technologies-sub{ font-size:.98rem }
  .mnb-technologies-hub{ --hub-size: 200px; }
}





/* --- Ripple highlight (cursor-tracked) ------------------ */
.mnb-technologies-pill{
  /* initial cursor center (updated by JS on the fly) */
  --x: 50%;
  --y: 50%;
  --ripple-alpha: .14;        /* base opacity */
  --ripple-alpha-hover: .22;  /* on hover */
  --ripple-size: 140px;       /* ripple diameter */

  /* augment existing shine background with a ripple layer */
  background-image:
    radial-gradient(
      var(--ripple-size) var(--ripple-size) at var(--x) var(--y),
      rgba(255,255,255, var(--ripple-alpha)),
      rgba(255,255,255, 0) 60%
    ),
    /* keep your existing diagonal shine sweep as 2nd layer */
    linear-gradient(120deg, transparent 0%, transparent 35%, rgba(255,255,255,.35) 50%, transparent 65%, transparent 100%);
  background-size: auto, 220% 100%;
  background-repeat: no-repeat, no-repeat;
}



.mnb-technologies-pill:hover{
  /* slightly stronger ripple when hovering */
  --ripple-alpha: var(--ripple-alpha-hover);
}



/* Keyboard focus fallback: put ripple in the center */
.mnb-technologies-pill:focus-visible{
  --x: 50%;
  --y: 50%;
}


/* Align column titles with their pill direction */
.mnb-technologies-colwrap--left .mnb-technologies-coltitle {
  text-align: right;
  justify-content: flex-end;  /* if icon + text should hug the right */
}



.mnb-technologies-colwrap--right .mnb-technologies-coltitle {
  text-align: left;
  justify-content: flex-start;
}





/* ===== Footer Styles (Prefixed) ===== */
.mnb-footer{
  position: relative;
  color: #e7edf6;
  background:
    radial-gradient(1200px 420px at 10% -10%, rgba(0,207,255,.10), transparent 60%),
    radial-gradient(1000px 420px at 100% 0%, rgba(106,189,69,.10), transparent 60%),
    linear-gradient(180deg, #0f1a2a 0%, #0b1524 100%);
  border-top: 1px solid rgba(255,255,255,.08);
  overflow: clip;
}



/* glossy edge */
.mnb-footer-edge{
  height: 10px;
  background: linear-gradient(90deg, rgba(106,189,69,.0), rgba(106,189,69,.65), rgba(0,207,255,.65), rgba(44,76,117,.65), rgba(0,207,255,.65), rgba(106,189,69,.0));
  filter: blur(8px);
  opacity: .55;
}



/* grid */
.mnb-footer-grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr .85fr .95fr;
  gap: clamp(18px, 2.6vw, 28px);
  padding: clamp(28px, 4.5vw, 56px) 0;
}


.mnb-footer-col{ min-width: 0; }



.mnb-footer-title{
  margin: 0 0 .7rem 0;
  font-size: clamp(1rem, 1.6vw, 1.05rem);
  color: #fff;
  letter-spacing: .2px;
}


.mnb-footer-blurb{ margin:.6rem 0 1.1rem 0; color:#c8d4e6; }



/* links */
.mnb-footer-links{ list-style:none; margin:0; padding:0; }


.mnb-footer-links li{ margin:.35rem 0; }


.mnb-footer-links a,
.mnb-footer-text{
  font-size:.95rem;
  color:#d2dcef;
  text-decoration:none;
}


.mnb-footer-links a:hover{ color:#fff; }



.mnb-footer-link-ani{ position:relative; }


.mnb-footer-link-ani::after{
  content:"";
  position:absolute; left:0; bottom:-2px; height:2px; width:0%;
  background: linear-gradient(90deg, var(--mnb-green), var(--mnb-aqua));
  transition: width .25s ease;
  border-radius: 2px;
}


.mnb-footer-link-ani:focus-visible::after,
.mnb-footer-link-ani:hover::after{ width:100%; }



/* brand lockup */
.mnb-footer-logo-pill{
  display:inline-grid; place-items:center;
  width:40px; height:40px; border-radius:50%;
  background: radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.18), rgba(255,255,255,.06));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.14), 0 6px 20px rgba(0,0,0,.25);
  margin-right:.55rem; color:#fff;
}


.mnb-footer-logo-name{
  font-weight:800; letter-spacing:.2px;
  color:#fff; font-size: clamp(1.05rem, 2vw, 1.2rem);
}


.mnb-footer-brand{ display:flex; align-items:center; }



/* social */
.mnb-footer-social{
  display:flex; gap:.6rem; list-style:none; padding:0; margin:.8rem 0 0 0;
}


.mnb-footer-icon-btn{
  display:inline-grid; place-items:center;
  width:38px; height:38px; border-radius:12px;
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.12);
  color:#e7edf6;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}


.mnb-footer-icon-btn:hover{ transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,0,0,.28); color:#fff; }


.mnb-footer-icon-btn:focus-visible{ outline:2px solid var(--mnb-aqua); outline-offset:2px; }



/* bottom bar */
.mnb-footer-bottom{ border-top: 1px solid rgba(255,255,255,.08); }


.mnb-footer-bottom-row{
  display:flex; align-items:center; justify-content:space-between;
  gap: 1rem; padding: 14px 0 18px;
}


.mnb-footer-copy{ margin:0; color:#b7c6dc; font-size:.95rem; }


.mnb-footer-legal{ list-style:none; display:flex; gap:1rem; margin:0; padding:0; }


.mnb-footer-legal a{ color:#cdd8eb; font-size:.95rem; }


.mnb-footer-legal a:hover{ color:#fff; }



/* back to top */
.mnb-footer-backtop{
  position: fixed; right: 18px; bottom: 18px;
  width:44px; height:44px; border-radius:14px;
  display:grid; place-items:center;
  color:#0e1726; background: linear-gradient(180deg, var(--mnb-aqua), var(--mnb-green));
  box-shadow: 0 10px 28px rgba(0,0,0,.30);
  border: none; cursor: pointer; opacity: 0; visibility: hidden; transform: translateY(10px);
  transition: opacity .2s ease, transform .2s ease, visibility .2s ease, box-shadow .2s ease;
  z-index: 40;
}


.mnb-footer-backtop.show{ opacity:1; visibility:visible; transform: translateY(0); }


.mnb-footer-backtop:hover{ box-shadow: 0 14px 36px rgba(0,0,0,.38); }


.mnb-footer-backtop:focus-visible{ outline: 2px solid #fff; outline-offset: 3px; }



/* responsive */
@media (max-width: 1024px){
  .mnb-footer-grid{ grid-template-columns: 1fr 1fr; }
}


@media (max-width: 640px){
  .mnb-footer-grid{ grid-template-columns: 1fr; }
  .mnb-footer-bottom-row{ flex-direction: column; align-items:flex-start; }
  .mnb-footer-legal{ gap:.8rem; flex-wrap: wrap; }
}



/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .mnb-footer-icon-btn,
  .mnb-footer-backtop{ transition: none; }
}




/* =============== WhatsApp Floating CTA =============== */
.mnb-whatsapp{
  --mnb-wa-size: 54px;                 /* circle size on desktop */
  --mnb-wa-gap: 18px;                  /* edge spacing */
  --mnb-wa-radius: 18px;               /* pill rounding when label is visible */

  position: fixed;
  right: calc(var(--mnb-wa-gap) + env(safe-area-inset-right));
  bottom: calc(var(--mnb-wa-gap) + env(safe-area-inset-bottom));
  z-index: 60;                         /* above footer/backdrop, below modals */
  display: inline-flex; align-items: center; gap: .6rem;

  min-height: var(--mnb-wa-size);
  border-radius: var(--mnb-wa-radius);
  color: #0b1a2a;
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}



.mnb-whatsapp i{
  display:grid; place-items:center;
  width: var(--mnb-wa-size); height: var(--mnb-wa-size);
  border-radius: 999px;
  background: #25D366;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.06);
  font-size: 2rem;
  color: white;
}



.mnb-whatsapp .mnb-whatsapp-label{
  font-weight: 700;
  letter-spacing: .2px;
  color: #fff;
  white-space: nowrap;
}



/* Hover / focus */
.mnb-whatsapp:hover{ transform: translateY(-2px); box-shadow: 0 14px 36px rgba(0,0,0,.34); }


.mnb-whatsapp:focus-visible{ outline: 2px solid #fff; outline-offset: 3px; }



/* Compact style (auto on small screens) */
@media (max-width: 640px){
  .mnb-whatsapp{
    --mnb-wa-size: 48px;
    --mnb-wa-gap: 14px;
    padding: 0;                        /* icon-only bubble */
    border-radius: 999px;
  }
  .mnb-whatsapp .mnb-whatsapp-label{ display:none; }
  .mnb-whatsapp i{ font-size: 1.2rem; }
}



/* Avoid overlapping with back-to-top button if you use it (moves WA left a bit) */
.mnb-footer-backtop ~ .mnb-whatsapp,
.mnb-whatsapp.with-backtop{
  /*right: calc(18px + env(safe-area-inset-right) + 56px);  56px ~ backtop width + gap */
}



/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .mnb-whatsapp{ transition: none; }
}



/* Developer credit (keep) */
.mnb-footer-dev{
  font-size:.9rem;
  color:#9fb1ca;
}


.mnb-footer-dev a{
  font-weight:600;
  color:#fff;
  text-decoration:none;
}


.mnb-footer-dev a:hover{ color:var(--mnb-aqua); }



/* =====================================================
   EXTRA RESPONSIVE ENHANCEMENTS (added)
   These tighten spacing/columns at small & medium widths.
===================================================== */

/* ABOUT: grid & spacing */
@media (max-width: 1200px){
  .mnb-about-grid{ gap: clamp(var(--mnb-s-5), 4vw, var(--mnb-s-7)); }
}


@media (max-width: 1024px){
  .mnb-about-grid{ grid-template-columns: 1fr; }
  .mnb-about-right{ order:-1; margin-bottom: var(--mnb-s-5); }
  .mnb-about-title{ font-size: clamp(1.9rem, 6vw, 2.3rem); }
  .mnb-about-lead{ font-size: clamp(1rem, 1.8vw, 1.1rem); }
}


@media (max-width: 640px){
  .mnb-about-ctas{ gap:.6rem; }
  .mnb-about-copy p{ font-size: .98rem; }
}


@media (max-width: 420px){
  .mnb-about-ctas{ flex-direction: column; }
}



/* ABOUT: KPIs & icon tiles */
@media (max-width: 860px){
  .mnb-kpis{ grid-template-columns: repeat(2,1fr); }
  .mnb-icon-tiles{ grid-template-columns: repeat(2,1fr); }
}


@media (max-width: 560px){
  .mnb-kpis, .mnb-icon-tiles{ grid-template-columns: 1fr; }
}



/* ALT FEATURE: icon grid densifies on small */
@media (max-width: 560px){
  .mnb-feature-icons{ grid-template-columns: repeat(2,1fr); }
}


@media (max-width: 380px){
  .mnb-feature-icons{ grid-template-columns: 1fr; }
}



/* SERVICES: header stack + card fit */
@media (max-width: 720px){
  .mnb-service-head{ flex-direction: column; align-items: flex-start; gap: .8rem; }
}


@media (max-width: 560px){
  .mnb-service-btn-outline{ width:100%; text-align:center; }
  .mnb-service-card{ padding: 66px 16px 18px; min-height: 200px; }
}


@media (max-width: 400px){
  .mnb-service-badge{ width:54px; height:54px; top:-14px; }
  .mnb-service-card-title{ font-size: 1rem; }
  .mnb-service-card-text{ font-size:.94rem; }
}



/* WHY CHOOSE US: room to breathe */
@media (max-width: 920px){
  .mnb-why-chooseus{ padding: clamp(44px,7vw,72px) 0; }
}


@media (max-width: 560px){
  .mnb-why-chooseus__grid{ gap: 1rem; }
  .mnb-why-chooseus__feature{ padding: 1rem; }
}


@media (max-width: 380px){
  .mnb-why-chooseus__title{ font-size: clamp(1.4rem, 7vw, 1.8rem); }
}



/* TECHNOLOGIES: tiny-screen polish */
@media (max-width: 520px){
  .mnb-technologies-sub{ font-size: .96rem; }
}


@media (max-width: 380px){
  .mnb-technologies-title{ font-size: clamp(1.45rem, 8.5vw, 1.8rem); }
}



/* Hide connector arms earlier on mids */
@media (max-width: 1040px){
  .mnb-technologies-pill::after,
  .mnb-technologies-pill::before{ display:none; }
}



/* FOOTER: tighter rhythm on mobile */
@media (max-width: 640px){
  .mnb-footer-bottom-row{ padding: 12px 0 16px; }
}


@media (max-width: 420px){
  .mnb-footer-copy, .mnb-footer-legal a{ font-size:.9rem; }
}



/* WHATSAPP CTA: ensure no clash on xs widths */
@media (max-width: 360px){
  .mnb-whatsapp{ --mnb-wa-gap: 12px; }
}



/* High DPI / very tall: soften big glows */
@media (min-height: 980px) and (min-width: 1024px){
  .mnb-about--clean::before,
  .mnb-about--clean::after{ filter: blur(22px); opacity:.45; }
}



/* Reduced motion fallback (safety) */
@media (prefers-reduced-motion: reduce){
  .mnb-kpi, .mnb-icon-tile{ transform:none !important; }
}





/* =====================================================
   TESTIMONIALS — Polished visuals + stronger hierarchy
   Drop this AFTER your existing CSS to override styles.
===================================================== */

.mnb-testimonials{
  --t-accent: linear-gradient(90deg, var(--mnb-aqua), var(--mnb-green));
  --t-surface: #fff;
  --t-line: var(--mnb-line, #E8EEF6);
  --t-soft: color-mix(in oklab, var(--mnb-navy) 5%, #fff);
  --t-shadow-1: 0 10px 24px rgba(18,32,54,.08);
  --t-shadow-2: 0 18px 44px rgba(18,32,54,.14);
  position:relative;
  padding: clamp(52px, 7vw, 100px) 0;
  border-top: 1px solid var(--t-line);
  overflow: clip;
  isolation: isolate;
}



.mnb-testimonials-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(900px 420px at 0% 0%, rgba(44,76,117,.06), transparent 60%),
    radial-gradient(1000px 520px at 100% 100%, rgba(106,189,69,.10), transparent 60%),
    linear-gradient(180deg, #fff 0%, #f7fbff 100%);
  mask: radial-gradient(70% 120% at 50% 0%, #000 70%, transparent 100%);
}


.mnb-testimonials-container{ width:min(1140px, 92vw); margin-inline:auto; position:relative; z-index:1; }



/* Header */
.mnb-testimonials-head{ text-align:center; max-width:880px; margin:0 auto clamp(18px, 3vw, 30px); }


.mnb-testimonials-eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-weight:900; letter-spacing:.06em; text-transform:uppercase; color:var(--mnb-navy);
  padding:.38rem .8rem; border-radius:999px;
  background: linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.00));
  border:1px solid color-mix(in oklab, var(--mnb-navy) 14%, #fff);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
}


.mnb-testimonials-eyebrow .dot{
  width:9px; height:9px; border-radius:50%;
  background: var(--t-accent);
  box-shadow: 0 0 0 5px color-mix(in oklab, var(--mnb-aqua) 25%, transparent);
}


.mnb-testimonials-title{
  margin:.5rem 0 .4rem; line-height:1.12;
  font-weight:900; color:var(--mnb-navy);
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  text-wrap: balance;
}


.mnb-testimonials-sub{ margin:0; color:var(--mnb-muted); font-size:clamp(1rem, 1.2vw, 1.08rem); }



/* Viewport / Track */
.mnb-testimonials-viewport{ position:relative; margin-top: clamp(16px,2.6vw,22px); }


.mnb-testimonials-track{
  list-style:none; margin:0; padding: 6px 2px 10px;
  display:grid; grid-auto-flow: column; gap: clamp(14px, 1.8vw, 20px);
  grid-auto-columns: calc(100% - 24px);
  overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling: touch;
  scroll-padding-inline: 2px;
}


.mnb-testimonials-track::-webkit-scrollbar{ display:none; }


.mnb-testimonials-track{ scrollbar-width:none; }



@media (min-width:720px){  .mnb-testimonials-track{ grid-auto-columns: calc(50% - 18px); } }


@media (min-width:1024px){ .mnb-testimonials-track{ grid-auto-columns: calc(33.333% - 18px); } }



/* Card */
.mnb-testimonial-card{
  scroll-snap-align:start;
  position:relative; display:grid; grid-template-rows:auto 1fr; gap:12px;
  padding: clamp(16px, 1.8vw, 20px) clamp(16px, 1.6vw, 20px);
  background: linear-gradient(#fff,#fff) padding-box,
             conic-gradient(from 140deg, rgba(106,189,69,.45), rgba(0,207,255,.45), rgba(44,76,117,.45), rgba(106,189,69,.45)) border-box;
  border:1.6px solid transparent; border-radius:22px;
  box-shadow: var(--t-shadow-1);
  transition: transform .22s cubic-bezier(.22,.61,.36,1), box-shadow .22s cubic-bezier(.22,.61,.36,1), filter .22s;
}


.mnb-testimonial-card::after{
  content:""; position:absolute; inset:-20%;
  background: linear-gradient(110deg, transparent 40%, rgba(255,255,255,.55) 50%, transparent 62%);
  transform: translateX(-120%) rotate(8deg); opacity:0; pointer-events:none;
}


.mnb-testimonial-card::before{
  content:"“"; position:absolute; right:12px; top:6px; font-size:44px; line-height:1;
  background: var(--t-accent); -webkit-background-clip:text; background-clip:text; color:transparent;
  opacity:.16; pointer-events:none;
}


.mnb-testimonial-card:hover{ transform: translateY(-6px); box-shadow: var(--t-shadow-2); }


.mnb-testimonial-card:hover::after{ animation: t-shine 1100ms ease-out forwards; }


@keyframes t-shine{ to{ transform:translateX(120%) rotate(8deg); opacity:.9; } }



/* Head */
.mnb-testimonial-head{ display:flex; align-items:center; gap:.8rem; }


.mnb-avatar{
  width:48px; height:48px; border-radius:50%; object-fit:cover;
  background:#fff;
  box-shadow: 0 3px 12px rgba(0,0,0,.15);
  outline: 2px solid #fff;
  border: 2px solid transparent;
  background:
    linear-gradient(#fff,#fff) padding-box,
    var(--t-accent) border-box;
}


.mnb-person-name{ font-weight:900; color:var(--mnb-ink,#152238); }


.mnb-person-role{ color:var(--mnb-muted); font-weight:700; letter-spacing:.02em; }



/* Stars */
.mnb-stars{
  display:flex; gap:2px; font-size:.95rem; line-height:1;
  background: linear-gradient(180deg,#FFD37A,#F8B84E);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow: 0 1px 0 rgba(0,0,0,.06);
}


.mnb-stars i{ font-style:normal; }



/* Quote */
.mnb-quote{ margin:0; color:var(--mnb-ink); position:relative; padding-top:2px; }


.mnb-quote p{ margin:0 0 .5rem; line-height:1.6; }


.mnb-quote cite{ display:block; font-style:normal; color:var(--mnb-muted); font-weight:700; letter-spacing:.02em; }



/* Controls (non-overlap placement) */
.mnb-testimonials-controls{
  position:absolute; inset:0; display:flex; justify-content:space-between; align-items:center;
  pointer-events:none; padding: 0 2px;
}


.mnb-testimonials-btn{
  pointer-events:all; margin-top: 0;
  width:42px; height:42px; border-radius:999px;
  display:grid; place-items:center;
  color:var(--mnb-navy); background:linear-gradient(180deg,#fff,#f7fbff);
  border:1px solid var(--t-line); box-shadow: var(--t-shadow-1);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}


.mnb-testimonials-btn:hover{ transform: translateY(-2px); box-shadow: var(--t-shadow-2); }


.mnb-testimonials-btn:focus-visible{ outline:2px solid var(--mnb-aqua); outline-offset:3px; }



/* Dots */
.mnb-testimonials-dots{ display:flex; justify-content:center; gap:.45rem; margin-top: clamp(12px,1.6vw,16px); }


.mnb-testimonials-dot{
  width:10px; height:10px; border-radius:999px;
  background: color-mix(in oklab, var(--mnb-navy) 20%, #cfd9ea);
  border:1px solid color-mix(in oklab, var(--mnb-navy) 18%, #fff);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
  opacity:.7; transform: translateZ(0);
  transition: transform .18s ease, opacity .18s ease, background .3s ease;
}


.mnb-testimonials-dot[aria-selected="true"]{
  opacity:1; transform: scale(1.18);
  background: var(--t-accent); border-color: transparent;
}



/* Reveal hooks */
.mnb-testimonials-head, .mnb-testimonial-card{ opacity:0; transform: translateY(18px); }


.mnb-reveal-in{ animation: t-reveal 640ms cubic-bezier(.22,.61,.36,1) forwards; }


@keyframes t-reveal{ to{ opacity:1; transform:none; } }



/* Responsive polish */
@media (max-width: 560px){
  .mnb-testimonials-controls{ align-items:flex-end; padding-bottom: 56px; }
  .mnb-testimonials-btn{ display:none; } /* rely on swipe */
  .mnb-testimonial-card{ padding: 14px 14px; }
}


@media (max-width: 400px){
  .mnb-testimonials-title{ font-size: clamp(1.45rem, 7.6vw, 1.8rem); }
  .mnb-quote p{ font-size:.98rem; }
}



/* A11y & reduced motion */
.mnb-testimonial-card:focus-within{ outline:3px solid color-mix(in oklab, var(--mnb-aqua) 60%, transparent); outline-offset:3px; }


@media (prefers-reduced-motion: reduce){
  .mnb-testimonial-card,
  .mnb-testimonials-btn{ transition:none !important; }
  .mnb-testimonials-head, .mnb-testimonial-card{ opacity:1; transform:none; animation:none !important; }
}



/* Fallback avatar */
.mnb-avatar-fallback{
  width:48px; height:48px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:1rem;
  color:#fff; text-transform:uppercase;
  box-shadow: 0 3px 12px rgba(0,0,0,.15);
}




/* Minimal fallback styling (keeps your existing testimonial CSS) */
.mnb-avatar { width:48px; height:48px; border-radius:50%; object-fit:cover; background:#fff; outline:2px solid #fff; border:2px solid transparent; display:inline-grid; place-items:center; }


.mnb-avatar-missing { background:linear-gradient(180deg,#2c4c75,#19314e); color:#fff; box-shadow:0 3px 12px rgba(0,0,0,.15); }


.mnb-avatar-missing i { font-size:20px; line-height:1; }

/* =========================================================
   HERO SLIDER — Webzolt look (logo colors, soft gradients)
   Full merged stylesheet (base + right-side redesigns, spacing tuned)
   Requires Font Awesome 6 (brands + solid)
========================================================= */

/* ---------- Theme (uses tokens from mnb-core.css if present) ---------- */
:root{
  --mnb-green:#6abd45;
  --mnb-navy:#2c4c75;
  --mnb-aqua:#00CFFF;
  --mnb-ink:#122036;
  --mnb-muted:#667693;

  --mnb-bg:#F5F7FA;
  --mnb-surface:#FFFFFF;
  --mnb-line:#E8EEF6;

  --mnb-hero-overlap:68px;
  --mnb-slide-ms:5600;
  --mnb-radius:18px;
  --mnb-shadow:0 18px 44px rgba(0,0,0,.14);

  /* Showcase cluster baseline (floor) + hover tilt */
  --cluster-floor:10%;
  --hover-tilt:0deg;

  /* legacy showcase vars (kept for reference) */
  --mx-purple:#7a3df2;
  --mx-purple-2:#c33fff;
  --mx-deep:#231a40;
  --mx-card:#ffffff;
}



/* ---------- Base / overlap-safety ---------- */
[id]{ scroll-margin-top:calc(var(--mnb-hero-overlap,68px) + 12px); }



.mnb-hero{
  position:relative; z-index:0;
  margin-top:calc(var(--mnb-hero-overlap) * -1);
  padding-top:var(--mnb-hero-overlap);
  background:
    radial-gradient(1100px 420px at 90% 10%, rgba(0,207,255,.08), transparent 60%),
    radial-gradient(900px 360px at 0% 100%, rgba(106,189,69,.10), transparent 60%),
    linear-gradient(180deg,#fff 0%,#F5F7FA 100%);
}



.mnb-container{ width:min(1160px, calc(100% - 32px)); margin-inline:auto; }



/* ---------- Slider shell ---------- */
.mnb-slider{ position:relative; overflow:clip; border-radius:0; isolation:isolate; }



/* Progress: class + id fallbacks (covers both markup variants) */
.mnb-progress,
#mnb-progress{
  position:absolute; inset:0 auto auto 0; height:3px; width:100%;
  background:linear-gradient(90deg, rgba(0,0,0,.06), rgba(0,0,0,.06));
  z-index:5; pointer-events:none;
}


.mnb-progress-inner,
#mnb-progress .mnb-progress-inner,
#mnb-progress-inner{
  height:100%; width:0%;
  background:linear-gradient(90deg, var(--mnb-green), var(--mnb-navy));
  transform-origin:left center;
  transition:none; /* controlled by JS */
}



/* ---------- Slides track ---------- */
.mnb-slides{
  display:grid; grid-auto-flow:column; grid-auto-columns:100%;
  will-change:transform;
  transition: transform .7s cubic-bezier(.2,.8,.2,1);
}



/* ---------- Single slide ---------- */
.mnb-slide{
  position:relative;
  min-height:clamp(520px, 68vh, 760px);
  display:flex; align-items:center;
}


.mnb-slide-glow{
  position:absolute; inset:-8% -2% -8% -2%;
  background:
    radial-gradient(700px 360px at 85% 20%, rgba(0,207,255,.10), transparent 60%),
    radial-gradient(700px 360px at 15% 80%, rgba(106,189,69,.13), transparent 60%);
  filter:blur(14px); z-index:0; pointer-events:none;
}



/* ---------- Grid (spacing tuned) ---------- */
.mnb-hero-grid{
  position:relative; z-index:1;
  display:grid; align-items:center;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px, 4vw, 56px);
  padding-inline:clamp(12px, 3vw, 24px);
}



/* ---------- Left column (copy) ---------- */
.mnb-hero-intro .mnb-kicker{
  display:inline-block;
  font:600 12px/1.1 "Inter", system-ui, sans-serif;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--mnb-navy);
  background:rgba(44,76,117,.08);
  border:1px solid rgba(44,76,117,.18);
  padding:8px 12px; border-radius:999px;
}


.mnb-hero-intro h1{
  font:800 clamp(26px,5vw,44px)/1.12 "Inter", system-ui, sans-serif;
  color:var(--mnb-ink); margin:14px 0 10px;
}


.mnb-accent{
  background:linear-gradient(90deg, var(--mnb-green), var(--mnb-navy));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}


.mnb-hero-intro p{
  color:#2c3e57; font:400 clamp(15px,1.2vw,18px)/1.7 "Inter", system-ui, sans-serif;
  max-width:56ch;
}


.mnb-hero-meta{
  display:flex; flex-wrap:wrap; gap:10px 16px; margin:16px 0 22px; padding:0;
  list-style:none; color:#2b3a52;
}


.mnb-hero-meta li{ display:flex; align-items:center; gap:8px; }


.mnb-hero-meta i{ color:var(--mnb-green); }



/* ---------- CTAs ---------- */
.mnb-ctas{ display:flex; flex-wrap:wrap; gap:12px; margin-top:6px; }


.mnb-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 16px; border-radius:12px; border:1px solid transparent;
  font:600 14px/1 "Inter", system-ui, sans-serif;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
  will-change:transform;
}


.mnb-btn-primary{ background:linear-gradient(90deg, var(--mnb-green), var(--mnb-navy)); color:#fff; box-shadow:var(--mnb-shadow); }


.mnb-btn-primary:hover{ transform:translateY(-1px); }


.mnb-btn-outline{ background:#fff; color:var(--mnb-ink); border-color:#d6e1f0; }


.mnb-btn-outline:hover{ background:#f6f9ff; transform:translateY(-1px); }



/* =========================================================
   RIGHT SIDE VISUALS
   (Use in HTML: .art-showcase, .art-seo, .art-cloud; legacy .art-devices kept)
========================================================= */

/* ---------- Slide 1 “Showcase” (desktop + laptop + tablet + phone) ---------- */
.mnb-right.art-showcase{
  position:relative; width:100%;
  height:min(540px, 60vh); max-height:640px;
  display:grid; place-items:center;
  transform-style:preserve-3d; perspective:1400px;
  padding-inline:clamp(8px, 1.5vw, 16px);
  --floor-ellipse:#0b17310d;
}


.mnb-right.art-showcase::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  bottom:calc(var(--cluster-floor) - 3%); width:68%; height:26%;
  background:radial-gradient(50% 60% at 50% 50%, rgba(7,19,45,.22), transparent 70%);
  filter:blur(8px); pointer-events:none; z-index:0;
}


@media (min-height: 820px){
  .mnb-right.art-showcase{ transform: translateY(8%); }
}


.mnb-right.art-showcase:hover{ --hover-tilt:.5deg; }



.dev{ position:absolute; will-change:transform,opacity; }



/* Desktop (iMac) */
.dev-imac{
  width:min(640px, 60vw);
  left:50%; bottom:var(--cluster-floor);
  transform: translate(-50%, -2%) rotateY(-6deg) rotateX(calc(.4deg + var(--hover-tilt))) translateZ(0);
  filter:drop-shadow(0 18px 44px rgba(0,0,0,.18));
  z-index:2;
}


.imac-frame{
  position:relative;
  background:#0e1024; border-radius:18px; padding:14px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.06);
}


.imac-frame::after{
  content:""; position:absolute; inset:0; border-radius:18px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), inset 0 -2px 8px rgba(0,0,0,.35);
  pointer-events:none;
}


.imac-screen{
  position:relative; border-radius:12px; overflow:hidden; background:#1b1f3a; aspect-ratio:16/9;
}


.imac-screen::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.14), transparent 28%),
    radial-gradient(200px 100px at 0% 0%, rgba(255,255,255,.16), transparent 60%);
  mix-blend-mode:screen;
}



/* Brand gradient animation */
@keyframes mnbBrandCycle {
  0%{ background-position:0% 50%, 0% 50%; }
  50%{ background-position:100% 50%, 100% 50%; }
  100%{ background-position:0% 50%, 0% 50%; }
}


.hero-brand{
  position:relative; width:100%; height:100%; overflow:hidden;
  background:
    radial-gradient(180px 180px at 80% 22%, rgba(255,255,255,.16), transparent 60%),
    linear-gradient(135deg, var(--mnb-green), var(--mnb-navy));
  background-size:auto, 220% 220%;
  background-position:center, 0% 50%;
  animation:mnbBrandCycle 14s ease-in-out infinite;
}


.mnb-right.art-showcase:hover .hero-brand{ animation-duration:8s; }



/* Optional dashed rings */
.hero-brand .g{ position:absolute; border-radius:50%; border:1px dashed rgba(255,255,255,.22); filter:blur(.2px); }


.hero-brand .g1{ top:16%; left:12%; width:70px; height:70px; }


.hero-brand .g2{ top:48%; left:66%; width:90px; height:90px; }


.hero-brand .g3{ bottom:10%; left:30%; width:80px; height:80px; }



/* Desktop tech chips grid */
.tech-chips{
  position:absolute; inset:0; display:grid; place-content:center;
  gap:14px; grid-template-columns:repeat(3, minmax(140px,1fr)); padding:22px;
  z-index:5;
}


.tech-chips .chip{
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.96);
  border:1px solid #e6eef8; border-radius:14px; padding:10px 12px;
  color:#102038; font:600 13px/1 "Inter", system-ui, sans-serif;
  box-shadow:0 10px 22px rgba(0,0,0,.10);
  transition: transform .18s ease, box-shadow .18s ease;
}


.tech-chips .chip i{ font-size:18px; color:var(--mnb-navy); }


.tech-chips .chip:hover{ transform:translateY(-2px); box-shadow:0 14px 26px rgba(0,0,0,.12); }



/* Laptop */
.dev-laptop{
  width:min(420px, 44vw);
  left:68%; bottom:calc(var(--cluster-floor) - 2%);
  transform:translate(-50%, 0) translateZ(40px) rotateY(-10deg) rotateX(calc(2deg + var(--hover-tilt)));
  animation:floatA 6.8s ease-in-out infinite;
  z-index:3;
}


.lap-lid{
  position:relative; background:#0f1726; border-radius:14px; padding:10px;
  box-shadow:0 16px 36px rgba(0,0,0,.22);
}


.lap-lid::after{
  content:""; position:absolute; inset:0; border-radius:14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), inset 0 -1px 0 rgba(0,0,0,.35);
  pointer-events:none;
}


.lap-screen{ position:relative; aspect-ratio:16/10; border-radius:10px; overflow:hidden; }


.lap-screen::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.10), transparent 36%);
  pointer-events:none; mix-blend-mode:screen;
}


.lap-screen.lap-brand{
  background:
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,0) 40%),
    linear-gradient(135deg, var(--mnb-green), var(--mnb-navy));
  background-size:100% 100%, 220% 220%;
  background-position:center, 0% 50%;
  animation:mnbBrandCycle 16s ease-in-out infinite;
}


.chip-row{
  display:flex; gap:12px; padding:16px; justify-content:flex-start; align-items:center;
}


.chip-row i{
  width:38px; height:38px; display:grid; place-items:center; font-size:18px;
  color:#fff; background:rgba(255,255,255,.16); border-radius:12px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}


.lap-base{ display: none; height:12px; border-radius:0 0 12px 12px; background:linear-gradient(180deg,#c8d5e8,#98afc9); filter:drop-shadow(0 12px 26px rgba(0,0,0,.22)); }



/* Tablet */
.dev-tablet{
  left:22%; bottom:calc(var(--cluster-floor) + 2%);
  width:min(320px, 36vw);
  transform:translate(-50%, 0) translateZ(20px) rotateY(18deg) rotateX(calc(2deg + var(--hover-tilt)));
  animation:floatB 7.4s ease-in-out infinite .2s;
  z-index:2;
}


.tab-glass{ position:relative; background:#fff; border-radius:22px; box-shadow:0 18px 40px rgba(0,0,0,.20); }


.tab-glass::before{
  content:""; position:absolute; inset:0; border-radius:22px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), inset 0 -1px 0 rgba(0,0,0,.05);
  pointer-events:none;
}


.tab-brand{
  position:absolute; inset:12px; border-radius:18px; overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,0) 40%),
    linear-gradient(135deg, var(--mnb-green), var(--mnb-navy));
  background-size:100% 100%, 220% 220%;
  background-position:center, 0% 50%;
  animation:mnbBrandCycle 18s ease-in-out infinite;
}


.tab-brand::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.10), transparent 40%);
  pointer-events:none; mix-blend-mode:screen; border-radius:18px;
}


.tab-chips{ position:absolute; inset: 44px; display:grid; gap:10px; grid-template-columns:repeat(2,1fr); }


.mini-chip{
  display:flex; align-items:center; gap:8px;
  background:#fff; color:#0f1a31; border:1px solid #e6eef8; border-radius:12px;
  padding:8px 10px; font:600 12px/1 "Inter"; box-shadow:0 10px 18px rgba(0,0,0,.10);
}


.mini-chip i{ color:var(--mnb-navy); }



/* Phone */
.dev-phone{
  left:62%; bottom:calc(var(--cluster-floor) + 4%);
  width:min(160px, 22vw); aspect-ratio:10/21;
  border-radius:26px; background:#0c1327; box-shadow:0 18px 40px rgba(0,0,0,.24);
  transform:translate(-50%, 0) translateZ(70px) rotateY(-6deg) rotateX(calc(4deg + var(--hover-tilt)));
  animation:floatC 6.2s ease-in-out infinite .1s;
  z-index:4;
}


.dev-phone .notch{ position:absolute; left:50%; top:6px; transform:translateX(-50%); width:44%; height:10px; background:#050a1a; border-radius:0 0 10px 10px; }


.ph-screen{ position:absolute; inset:10px; border-radius:22px; overflow:hidden; }


.ph-screen::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.08), transparent 42%);
  mix-blend-mode:screen; border-radius:22px;
}


.ph-screen.ph-brand{
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,0) 38%),
    linear-gradient(180deg, var(--mnb-navy), #0e2244);
}


.app-tiles{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; padding:12px; }


.app-tiles.icons{ gap:10px; padding:14px; }


.app-tiles.icons i{
  width:44px; height:44px; display:grid; place-items:center;
  background:rgba(255,255,255,.12); border-radius:12px; color:#eaf4ff; font-size:18px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10);
}



/* Hide any old stat cards if present */
.mnb-right.art-showcase .float.stat{ display:none !important; }



/* Floating motion keyframes */
@keyframes floatA{ 0%,100%{ transform:translate(-50%,0) translateZ(40px) rotateY(-10deg) rotateX(calc(2deg + var(--hover-tilt))) translateY(0) } 50%{ transform:translate(-50%,0) translateZ(40px) rotateY(-10deg) rotateX(calc(2deg + var(--hover-tilt))) translateY(-8px) } }


@keyframes floatB{ 0%,100%{ transform:translate(-50%,0) translateZ(20px) rotateY(18deg)  rotateX(calc(2deg + var(--hover-tilt))) translateY(0)} 50%{ transform:translate(-50%,0) translateZ(20px) rotateY(18deg)  rotateX(calc(2deg + var(--hover-tilt))) translateY(-10px)} }


@keyframes floatC{ 0%,100%{ transform:translate(-50%,0) translateZ(70px) rotateY(-6deg)  rotateX(calc(4deg + var(--hover-tilt))) translateY(0) } 50%{ transform:translate(-50%,0) translateZ(70px) rotateY(-6deg)  rotateX(calc(4deg + var(--hover-tilt))) translateY(-8px) } }



/* ---------- Slide 2: SEO mini-dashboard ---------- */
.mnb-right.art-seo{
  position:relative; width:100%; height:min(520px, 58vh); max-height:620px;
  display:grid; place-items:center; perspective:1200px; transform-style:preserve-3d;
  grid-template-columns:1fr 1fr; grid-template-rows:auto auto; gap:16px; align-content:center;
}


.art-seo .card{ background:#fff; border:1px solid #e6eef8; border-radius:16px; padding:16px; box-shadow:0 16px 36px rgba(0,0,0,.10); }


.art-seo .kpi{ grid-column:1; grid-row:1 / span 2; display:grid; place-items:center; padding:22px; }


.art-seo .kpi .ring{
  --val:92; width:160px; aspect-ratio:1/1; border-radius:50%;
  background:conic-gradient(var(--mnb-green) calc(var(--val)*1%), #e9f2fe 0);
  position:relative; display:grid; place-items:center;
}


.art-seo .kpi .ring::after{ content:""; position:absolute; inset:12px; border-radius:50%; background:#fff; box-shadow:inset 0 0 0 1px #e6eef8; }


.art-seo .kpi .ring span{ position:relative; font:800 34px/1 "Inter"; color:#163055; }


.art-seo .kpi .label{ margin-top:12px; font:600 13px/1.3 "Inter"; color:#2f4667; }


.art-seo .tiles{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:10px; }


.art-seo .tile{
  background:linear-gradient(180deg,#f9fbff,#eef4fe); border:1px solid #e3ecfb; border-radius:12px; padding:12px;
  display:grid; gap:6px; align-content:start;
}


.art-seo .tile i{ color:var(--mnb-navy); }


.art-seo .tile b{ color:#173259; font-weight:700; font-size:13px; }


.art-seo .tile span{ color:#2f4667; font-weight:600; font-size:12px; }


.art-seo .graph{ position:relative; min-height:140px; display:grid; align-content:end; }


.art-seo .graph .legend{ display:flex; gap:12px; margin-top:10px; }


.art-seo .legend .dot{ width:10px; height:10px; border-radius:50%; display:inline-block; background:var(--mnb-green); box-shadow:inset 0 0 0 1px rgba(0,0,0,.06); margin-right:6px; }


.art-seo .legend span:nth-child(2) .dot{ background:var(--mnb-navy); }


.art-seo .spark{
  position:absolute; inset:10px 10px 36px 10px; border-radius:10px; background:
    linear-gradient(180deg,rgba(44,76,117,.06),transparent),
    repeating-linear-gradient(0deg, transparent 0 38px, rgba(44,76,117,.08) 38px 39px),
    linear-gradient(90deg, rgba(106,189,69,.25), rgba(44,76,117,.25));
  mask:
    radial-gradient(14px 14px at 6% 72%, #000 96%, transparent 100%),
    radial-gradient(12px 12px at 18% 44%, #000 96%, transparent 100%),
    radial-gradient(16px 16px at 28% 66%, #000 96%, transparent 100%),
    radial-gradient(12px 12px at 40% 38%, #000 96%, transparent 100%),
    radial-gradient(16px 16px at 54% 58%, #000 96%, transparent 100%),
    radial-gradient(12px 12px at 66% 36%, #000 96%, transparent 100%),
    radial-gradient(16px 16px at 78% 52%, #000 96%, transparent 100%),
    radial-gradient(12px 12px at 90% 30%, #000 96%, transparent 100%);
}



/* ---------- Slide 3: Cloud pipeline ---------- */
.mnb-right.art-cloud{
  position:relative; width:100%; height:min(520px, 58vh); max-height:620px;
  display:grid; place-items:center; perspective:1200px; transform-style:preserve-3d;
}


.art-cloud .cloud{
  position:absolute; top:10%; left:50%; transform:translateX(-50%);
  width:140px; height:90px; display:grid; place-items:center;
  background:linear-gradient(180deg,#ffffff,#eef5ff); border:1px solid #e4ecf6; border-radius:60px;
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}


.art-cloud .cloud i{ font-size:34px; color:var(--mnb-navy); }



.art-cloud .racks{ position:absolute; bottom:12%; left:50%; transform:translateX(-50%); display:flex; gap:14px; }


.art-cloud .rack{
  width:110px; padding:14px 10px; border-radius:14px; background:#fff; border:1px solid #e6eef8;
  box-shadow:0 16px 36px rgba(0,0,0,.10); display:grid; place-items:center; gap:6px;
}


.art-cloud .rack i{ color:#20406a; font-size:18px; }


.art-cloud .rack em{ font:600 12px/1 "Inter"; color:#2b466b; font-style:normal; }



.art-cloud .guard{
  position:absolute; right:6%; top:20%;
  width:86px; height:86px; border-radius:50%;
  background:conic-gradient(var(--mnb-green) 0 240deg, #e9f2fe 0);
  display:grid; place-items:center; box-shadow:0 16px 36px rgba(0,0,0,.12);
}


.art-cloud .guard i{ color:#0f1a31; font-size:22px; }


.art-cloud .guard span{ font:800 12px/1 "Inter"; color:#0f1a31; }



.art-cloud .flow{ position:absolute; top:44%; left:10%; right:10%; height:2px; background:#e6eef8; }


.art-cloud .flow .dot{
  position:absolute; top:50%; transform:translate(-50%,-50%); width:8px; height:8px; border-radius:999px;
  background:var(--mnb-green); box-shadow:0 0 0 3px rgba(106,189,69,.18); animation:flow 3.2s linear infinite;
}


.art-cloud .flow .d1{ left:14%; animation-delay:0s; }


.art-cloud .flow .d2{ left:34%; animation-delay:.4s; }


.art-cloud .flow .d3{ left:58%; animation-delay:.8s; }


.art-cloud .flow .d4{ left:82%; animation-delay:1.2s; }


@keyframes flow{ 0%{ transform:translate(-50%,-50%) scale(.8); opacity:.6; } 50%{ transform:translate(-50%,-50%) scale(1); opacity:1; } 100%{ transform:translate(-50%,-50%) scale(.8); opacity:.6; } }



/* =========================================================
   (Legacy) Multi-device art (kept for compatibility)
========================================================= */
.mnb-right--multi-dev{
  position:relative; width:100%; height:min(520px, 58vh); max-height:620px;
  display:grid; place-items:center; perspective:1200px; transform-style:preserve-3d;
}


.mnb-right--multi-dev .mdv{ position:absolute; display:block; transform-style:preserve-3d; will-change:transform,opacity; }


.mnb-right--multi-dev .monitor{ width:min(520px, 50vw); aspect-ratio:16/10; transform:translateZ(0) rotateX(0deg) rotateY(-8deg) translateY(0); filter:drop-shadow(0 10px 30px rgba(0,0,0,.16)); }


.monitor .bezel{ background:#0f1726; border-radius:16px; padding:14px; height:100%; box-shadow:inset 0 0 0 1px rgba(255,255,255,.06); }


.monitor .window{ height:100%; border-radius:10px; background:linear-gradient(180deg,#0b1430,#101b3f); display:grid; place-items:center; overflow:hidden; }


.monitor .code{ width:82%; height:64%; display:grid; grid-template-columns:repeat(9, 1fr); grid-auto-rows:10px; gap:6px; opacity:.9; }


.monitor .code span{ display:block; border-radius:999px; background:rgba(0,207,255,.28); animation:codepulse 1.8s linear infinite alternate; }


@keyframes codepulse{ to{ transform:translateY(-1px); opacity:.7; } }


.mnb-right--multi-dev .tablet{ width:min(280px, 32vw); aspect-ratio:3/4; border-radius:22px; background:#fff; box-shadow:0 14px 36px rgba(0,0,0,.15); transform:translate(-48%, 6%) rotateY(18deg) rotateX(2deg) scale(.96); }


.tablet .screen{ inset:10px; position:absolute; border-radius:18px; background:linear-gradient(180deg,#e8f6ff,#c8e6ff); }


.mnb-right--multi-dev .phone{ width:min(180px, 24vw); aspect-ratio:10/21; border-radius:26px; background:#0c1327; box-shadow:0 14px 36px rgba(0,0,0,.18); transform:translate(56%,16%) rotateY(-18deg) rotateX(4deg) scale(1.02); }


.phone .notch{ position:absolute; left:50%; top:6px; transform:translateX(-50%); width:40%; height:10px; background:#050a1a; border-radius:0 0 10px 10px; }


.phone .screen{ position:absolute; inset:8px; border-radius:22px; background:linear-gradient(180deg,#0e1a3a,#112351); display:grid; place-items:center; }


.app-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }


.app-grid .app{ display:grid; place-items:center; width:44px; aspect-ratio:1/1; border-radius:12px; background:rgba(255,255,255,.08); color:#d9ecff; font-size:18px; }



/* Decorative gears + chips (legacy) */
.gears{ position:absolute; font-size:clamp(22px, 3vw, 28px); color:rgba(255,255,255,.5); filter:drop-shadow(0 4px 14px rgba(0,0,0,.25)); }


.g1{ left:8%; top:10%; animation:spin 16s linear infinite; }


.g2{ right:6%; bottom:12%; animation:spin 22s linear infinite reverse; }


@keyframes spin{ to{ transform:rotate(360deg); } }


.chip{ position:absolute; font:600 12px/1 "Inter", system-ui, sans-serif; padding:8px 10px; border-radius:999px; color:#0f1a31; background:rgba(255,255,255,.9); border:1px solid rgba(0,0,0,.06); box-shadow:0 8px 18px rgba(0,0,0,.08); }


.c-html{ left:10%; top:48%; }

 .c-css{ left:20%; top:72%; }

 .c-js{ left:38%; top:20%; }

 .c-ts{ left:52%; top:68%; }

 .c-react{ left:70%; top:32%; }

 .c-node{ right:20%; top:62%; }

 .c-php{ right:12%; top:16%; }

 .c-laravel{ right:30%; top:42%; }

 .c-sql{ left:56%; top:84%; }



/* ---------- Caption (badge + counter) ---------- */
.mnb-slide-caption{
  position:absolute; left:50%; bottom:12px; transform:translateX(-50%);
  display:flex; gap:10px; align-items:center; z-index:4;
}


.mnb-slide-chip{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; color:#0f1a31; border:1px solid #e4ecf6; padding:8px 12px; border-radius:999px;
  box-shadow:0 10px 18px rgba(0,0,0,.08);
  font:600 12px/1 "Inter", system-ui, sans-serif;
}


.mnb-slide-count{
  color:#3a4b6a; font:600 12px/1 "Inter", system-ui, sans-serif;
  background:rgba(255,255,255,.9); padding:8px 10px; border-radius:10px; border:1px solid #e6eef8;
  box-shadow:0 10px 18px rgba(0,0,0,.08);
}



/* ---------- Controls ---------- */
.mnb-slide-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  z-index:4; width:42px; aspect-ratio:1/1; display:grid; place-items:center;
  border:none; border-radius:999px; background:#fff;
  box-shadow:0 14px 32px rgba(0,0,0,.16);
  color:#0b1731; cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}


.mnb-slide-nav:hover{ transform:translateY(-50%) translateY(-1px); }


.mnb-slide-prev{  left: 5%; }


.mnb-slide-next{ right:clamp(8px, 2vw, 14px); }


.mnb-slide-nav i{ pointer-events:none; }



/* ---------- Dots (left rail on lg, bottom on mobile) ---------- */
.mnb-dots{
  position:absolute; left:clamp(8px, 2vw, 14px); bottom:clamp(14px, 2.6vw, 26px);
  display:flex; gap:10px; z-index:4; align-items:center;
}


.mnb-dot{
  width:9px; height:9px; border-radius:999px; border:0;
  background:#c6d4ea; opacity:.9; cursor:pointer;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);
  transition: transform .18s ease, background .18s ease;
}


.mnb-dot[aria-selected="true"]{ transform:scale(1.5); background:linear-gradient(90deg, var(--mnb-green), var(--mnb-navy)); }



/* Large view: vertical dots rail on the left */
@media (min-width:1024px){
  .mnb-dots{
    left:clamp(10px, 1.8vw, 18px);
    top:50%; bottom:auto; transform:translateY(-50%);
    flex-direction:column;
    background:rgba(255,255,255,.78);
    padding:10px; border-radius:14px; border:1px solid #e6eef8;
    box-shadow:0 18px 44px rgba(0,0,0,.12);
  }
}



/* ---------- Reveal anims ---------- */
.mnb-reveal{ opacity:0; transform:translateY(8px); }


.mnb-hero .is-in{ opacity:1; transform:none; transition:.6s ease; transition-delay:var(--delay, 0ms); }



/* ---------- Focus styles (a11y) ---------- */
.mnb-slide-nav:focus-visible,
.mnb-dot:focus-visible,
.mnb-btn:focus-visible{
  outline:2px solid transparent;
  box-shadow:0 0 0 3px rgba(0, 207, 255, .35), 0 10px 18px rgba(0,0,0,.08);
}



/* ---------- Responsiveness ---------- */
@media (max-width:1160px){
  .tech-chips{ grid-template-columns:repeat(3, minmax(120px,1fr)); gap:12px; }
}


@media (max-width:1024px){
  /* (fix) center dots on small screens, nudge prev away from edge */
  .mnb-dots{ left:50%; transform:translateX(-50%); bottom:clamp(12px, 3vw, 24px); }
  .mnb-slide-prev{ left: clamp(14px, 3vw, 32px); }

  .dev-imac{ width:min(560px, 88vw); }
  .dev-laptop{ width:min(360px, 60vw); }
  .dev-tablet{ width:min(260px, 44vw); }
}


@media (max-width:960px){
  .mnb-hero-grid{ grid-template-columns:1fr; gap:28px; }
  .mnb-right.art-showcase,
  .mnb-right.art-seo,
  .mnb-right.art-cloud{ height:360px; max-height:420px; }
  .mnb-slide-caption{ bottom:10px; }

  /* Re-position cluster for narrow widths */
  .dev-imac{ left:50%; bottom:12%; transform:translate(-50%, -2%) rotateY(-4deg) rotateX(calc(.4deg + var(--hover-tilt))); }
  .dev-laptop{ left:58%; bottom:10%; }
  .dev-tablet{ left:24%; bottom:14%; }
  .dev-phone{ left:66%; bottom:16%; }

  .art-seo{ grid-template-columns:1fr; }
  .art-seo .kpi{ grid-column:auto; grid-row:auto; }
}


@media (max-width:780px){
  .tech-chips{ grid-template-columns:repeat(2, minmax(120px,1fr)); }
}


@media (max-width:560px){
  .mnb-btn{ padding:11px 14px; border-radius:10px; }
  .mnb-hero-intro h1{ font-weight:800; }
  .mnb-hero-meta{ gap:8px 12px; }
  .dev-imac{ width:96%; }
  .dev-laptop{ width:70%; }
  .dev-tablet{ width:52%; }
  .dev-phone{ width:34%; }
}



/* =========================================================
   PROMO-STYLE ALIGNMENT (optional)
========================================================= */
.mnb-right.art-showcase.is-promo{ --cluster-floor:9%; }


.mnb-right.art-showcase.is-promo::after{
  bottom: calc(var(--cluster-floor) - 2.5%);
  width: 76%;
  height: 28%;
  background: radial-gradient(50% 60% at 52% 50%, rgba(7,19,45,.26), transparent 72%);
}


.art-showcase.is-promo .dev-imac{
  left:46%;
  bottom:var(--cluster-floor);
  transform: translate(-50%,0) rotateY(0deg) rotateX(.4deg) scale(1);
  z-index:2;
}


.art-showcase.is-promo .dev-tablet{
  left:72%;
  bottom:calc(var(--cluster-floor) + 6%);
  width:min(300px, 32vw);
  transform: translate(-50%,0) rotateY(0deg) rotateX(.6deg) rotateZ(-1deg) scale(.96);
  z-index:3;
  filter: drop-shadow(0 16px 38px rgba(0,0,0,.22));
}


.art-showcase.is-promo .dev-phone{
  left:82%;
  bottom:calc(var(--cluster-floor) - 2%);
  width:min(150px, 20vw);
  transform: translate(-50%,0) rotateY(0deg) rotateX(1deg) rotateZ(.4deg) scale(.98);
  z-index:4;
  filter: drop-shadow(0 18px 44px rgba(0,0,0,.28));
}


.art-showcase.is-promo .dev-laptop{ display:none; }


.art-showcase.is-promo.keep-laptop .dev-laptop{
  display:block;
  left:26%;
  bottom:calc(var(--cluster-floor) + 1%);
  width:min(340px, 36vw);
  transform: translate(-50%,0) rotateY(-4deg) rotateX(.8deg) scale(.9);
  z-index:1;
  filter: drop-shadow(0 14px 34px rgba(0,0,0,.18));
}


.art-showcase.is-promo .imac-screen::before{
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), transparent 30%),
    radial-gradient(220px 120px at 0% 0%, rgba(255,255,255,.18), transparent 60%);
}


.art-showcase.is-promo .lap-screen::before,
.art-showcase.is-promo .tab-brand::after,
.art-showcase.is-promo .ph-screen::before{ opacity:.95; }


@media (max-width:1024px){
  .art-showcase.is-promo .dev-imac{ left:50%; width:min(560px,88vw); }
  .art-showcase.is-promo .dev-tablet{ left:70%; bottom:calc(var(--cluster-floor) + 5%); }
  .art-showcase.is-promo .dev-phone{ left:78%; }
}


@media (max-width:960px){
  .art-showcase.is-promo .dev-imac{ bottom:12%; }
  .art-showcase.is-promo .dev-tablet{ bottom:16%; }
  .art-showcase.is-promo .dev-phone{ bottom:10%; }
}


@media (max-width:560px){
  .art-showcase.is-promo .dev-imac{ width:96%; }
  .art-showcase.is-promo .dev-tablet{ width:52%; }
  .art-showcase.is-promo .dev-phone{ width:34%; }
}


@media (min-height: 820px){
  .mnb-right.art-showcase.is-promo{ transform: translateY(8%); }
}



/* =========================================================
   HERO LAYOUT‑B BUBBLES (positions for .mnb-bubble helpers)
   Uses bubble styles defined in mnb-core.css
========================================================= */

.mnb-hero .mnb-bubble{ z-index:3 }

 /* sit above visual devices */

/* default placements – tweak as you like */
.mnb-hero .mnb-bubble.b1{ top:12%; left:14%; }


.mnb-hero .mnb-bubble.b2{ top:22%; right:12%; }


.mnb-hero .mnb-bubble.b3{ bottom:18%; left:10%; }


.mnb-hero .mnb-bubble.b4{ bottom:12%; right:16%; }



/* responsive shifts so bubbles don’t overlap */
@media (max-width:1024px){
  .mnb-hero .mnb-bubble.b1{ top:10%; left:8%; }
  .mnb-hero .mnb-bubble.b2{ top:16%; right:6%; }
  .mnb-hero .mnb-bubble.b3{ bottom:16%; left:6%; }
  .mnb-hero .mnb-bubble.b4{ bottom:10%; right:8%; }
}


@media (max-width:640px){
  .mnb-hero .mnb-bubble{ display:none; } /* keep hero uncluttered on small devices */
}

/* Load fonts (works even if your head include isn’t edited yet) */
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Poppins:wght@500;600;700&family=Fira+Code:wght@400;500&display=swap");

/* =========================================================
   Webzolt — SERVICES (polished spacing, type, motion)
   Prefix: .mnb-service-
   Fonts: Inter (body/UI), Poppins (headings), Fira Code (code)
========================================================= */
:root{ color-scheme: light dark; }



/* ---- Global font tokens ---- */
:root{
  --mnb-font-sans: "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mnb-font-heading: "Poppins", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mnb-font-mono: "Fira Code", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}



.mnb-service-root{
  /* Brand */
  --mnb-green:#59b53b; --mnb-aqua:#00cfff; --mnb-navy:#2c4c75; --mnb-violet:#7d5cff;
  --mnb-ink:#0b1422; --mnb-muted:#485a78; /* higher contrast */
  --mnb-bg:#f6f8fb; --mnb-surface:#ffffff; --mnb-line:#e6eef6;

  /* Type & rhythm (visibility-upgraded) */
  --fs-1: clamp(1rem, .9rem + .35vw, 1.08rem);
  --fs-2: clamp(1.16rem, 1.05rem + .65vw, 1.3rem);
  --fs-3: clamp(1.75rem, 1.25rem + 2.1vw, 2.2rem);
  --lh-body: 1.7;

  --s-1: clamp(8px, .6vw, 10px);
  --s-2: clamp(12px, .9vw, 14px);
  --s-3: clamp(16px, 1.2vw, 18px);
  --s-4: clamp(22px, 1.8vw, 26px);
  --s-5: clamp(28px, 2.4vw, 36px);
  --s-6: clamp(42px, 3.4vw, 56px);

  --radius: 20px;
  --radius-sm: 12px;
  --shadow: 0 6px 18px rgba(0,0,0,.08);
  --shadow-2: 0 14px 38px rgba(0,0,0,.12);
  --container: 1200px;

  /* Global body/UI font */
  font-family: var(--mnb-font-sans);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility;
  font-feature-settings: "liga","kern";

  background:
    radial-gradient(1200px 520px at 100% -10%, rgba(0,207,255,.10), transparent 60%),
    radial-gradient(1000px 420px at -10% 110%, rgba(89,181,59,.10), transparent 60%),
    var(--mnb-bg);
  color: var(--mnb-ink);
}



/* Headings in Poppins */
.mnb-service-root h1,
.mnb-service-root h2,
.mnb-service-root h3,
.mnb-service-root h4,
.mnb-service-root h5,
.mnb-service-root h6{
  font-family: var(--mnb-font-heading);
  font-weight: 700;
}



/* Body/UI ensure Inter */
.mnb-service-root p,
.mnb-service-root li,
.mnb-service-root a,
.mnb-service-root button,
.mnb-service-root input,
.mnb-service-root textarea,
.mnb-service-root select,
.mnb-service-root .mnb-service-chip,
.mnb-service-root .mnb-service-cta,
.mnb-service-root .mnb-service-kpi,
.mnb-service-root .mnb-service-cat{
  font-family: var(--mnb-font-sans);
}



/* Monospace */
.mnb-service-root code,
.mnb-service-root pre,
.mnb-service-root kbd,
.mnb-service-root samp{
  font-family: var(--mnb-font-mono);
}



/* Dark scheme adjustments */
@media (prefers-color-scheme: dark){
  .mnb-service-root{
    --mnb-bg:#0e1522; --mnb-surface:#121b2b; --mnb-line:#203049;
    --mnb-ink:#eef4ff; --mnb-muted:#b9c7df;
    --shadow:none; --shadow-2:none;
    background:
      radial-gradient(1200px 520px at 100% -10%, rgba(0,207,255,.08), transparent 60%),
      radial-gradient(1000px 420px at -10% 110%, rgba(89,181,59,.08), transparent 60%),
      var(--mnb-bg);
  }
}



.mnb-service-container{ width:min(var(--container),92%); margin-inline:auto }



/* ---------- Page head ---------- */
.mnb-service-pagehead{ padding: var(--s-5) 0 var(--s-2); position:relative; isolation:isolate; }


.mnb-service-eyebrow{
  display:inline-flex; gap:.55rem; align-items:center;
  color:var(--mnb-navy); font-weight:800; letter-spacing:.02em; font-size: var(--fs-1);
}


.mnb-service-eyebrow .dot{width:8px;height:8px;border-radius:999px;background:var(--mnb-green);display:inline-block}


.mnb-service-h1{ font-size: var(--fs-3); line-height:1.12; margin:.4rem 0; letter-spacing:-.018em }


.mnb-service-sub{ color:var(--mnb-muted); max-width:68ch; line-height: var(--lh-body); font-size: var(--fs-2); text-wrap: pretty }



/* Soft blobs */
.mnb-service-pagehead::before,
.mnb-service-pagehead::after{
  content:""; position:absolute; inset:auto; z-index:-1; filter: blur(22px);
  width:min(34vw,520px); height:min(24vw,340px); border-radius: 50%; pointer-events:none;
}


.mnb-service-pagehead::before{ left:-6%; top:-12%; background: radial-gradient(48% 52% at 50% 50%, rgba(0,207,255,.18), transparent 62%); }


.mnb-service-pagehead::after{  right:-10%; top: 10%; background: radial-gradient(50% 50% at 50% 50%, rgba(89,181,59,.18), transparent 62%); }



/* ---------- Filters ---------- */
.mnb-service-filters{ margin: var(--s-2) 0 var(--s-3); display:flex; flex-wrap:wrap; gap:10px }


.mnb-service-chip{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.56rem .98rem; border-radius:999px;
  font-weight:800; background:#fff; border:1px solid var(--mnb-line); color:color-mix(in srgb, var(--mnb-navy) 88%, black);
  box-shadow:var(--shadow); cursor:pointer; user-select:none; transition:.18s ease;
}


.mnb-service-chip:hover{ transform:translateY(-1px); box-shadow:var(--shadow-2) }


.mnb-service-chip:focus-visible{ outline:3px solid color-mix(in srgb, var(--mnb-aqua) 45%, transparent); outline-offset:2px }


.mnb-service-chip.is-active{
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--mnb-green) 20%, #fff),
    color-mix(in srgb, var(--mnb-aqua) 18%, #fff));
}



/* ---------- Services list ---------- */
.mnb-service-section{ padding: 6px 0 var(--s-6); position:relative; isolation:isolate; }


.mnb-service-section::before{
  content:""; position:absolute; right:-8px; bottom:-8px; width:240px; height:240px;
  background-image: radial-gradient(currentColor 1px, transparent 1px);
  background-size: 14px 14px; color: color-mix(in srgb, var(--mnb-line) 65%, transparent);
  mask: radial-gradient(60% 60% at 100% 100%, #000 58%, transparent 62%); pointer-events:none; z-index:-1;
}


.mnb-service-list{ display:grid; grid-template-columns:1fr; gap: var(--s-3) }



/* ---------- Card ---------- */
.mnb-service-card{
  content-visibility:auto; contain-intrinsic-size: 420px 820px;
  background: var(--mnb-surface); border:1px solid var(--mnb-line); border-radius: var(--radius);
  box-shadow: var(--shadow); overflow: clip; transition: box-shadow .22s ease, transform .22s ease;
  will-change: transform, box-shadow; position:relative;
}


.mnb-service-card:hover{ transform: translateY(-2px); box-shadow: var(--shadow-2) }



.mnb-service-card-inner{ display:grid; grid-template-columns: 0.45fr 0.55fr; align-items:stretch; }


.mnb-service-card.is-flipped .mnb-service-media{ order:2 }


.mnb-service-card.is-flipped .mnb-service-content{ order:1 }



@media (max-width: 980px){
  .mnb-service-card-inner{ grid-template-columns:1fr }
  .mnb-service-card.is-flipped .mnb-service-media,
  .mnb-service-card.is-flipped .mnb-service-content{ order:unset }
}



/* Media */
.mnb-service-media{
  position:relative; min-height:260px; background:#eef4ff; isolation:isolate; transform-style: preserve-3d;
}


@media (prefers-color-scheme: dark){ .mnb-service-media{ background:#0f1828 } }


.mnb-service-media img{
  width:100%; height:100%; object-fit:cover; display:block; aspect-ratio:16/10;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), filter .35s ease; will-change: transform, filter;
}


.mnb-service-media::before{
  content:""; position:absolute; inset:0; pointer-events:none; filter: blur(12px);
  mix-blend-mode:soft-light; z-index:1;
}


.mnb-service-card[data-cat="design"] .mnb-service-media::before{
  background: radial-gradient(36% 28% at 20% 18%, rgba(89,181,59,.20), transparent 60%),
              radial-gradient(24% 22% at 88% 12%, rgba(0,207,255,.18), transparent 62%);
}


.mnb-service-card[data-cat="dev"] .mnb-service-media::before{
  background: radial-gradient(36% 28% at 20% 18%, rgba(0,207,255,.22), transparent 60%),
              radial-gradient(24% 22% at 88% 12%, rgba(137,232,255,.20), transparent 62%);
}


.mnb-service-card[data-cat="mkt"] .mnb-service-media::before{
  background: radial-gradient(36% 28% at 20% 18%, rgba(44,76,117,.20), transparent 60%),
              radial-gradient(24% 22% at 88% 12%, rgba(153,179,214,.18), transparent 62%);
}


.mnb-service-card[data-cat="media"] .mnb-service-media::before{
  background: radial-gradient(36% 28% at 20% 18%, rgba(125,92,255,.20), transparent 60%),
              radial-gradient(24% 22% at 88% 12%, rgba(181,165,255,.18), transparent 62%);
}



/* ---------- Content ---------- */
.mnb-service-content{ padding: clamp(16px,2.2vw,28px) clamp(16px,2.2vw,28px) var(--s-3); display:flex; flex-direction:column; gap:12px; overflow:visible; }


.mnb-service-headrow{ display:flex; align-items:center; gap:12px; overflow:visible; }



/* Title with inline icon (anti-clipping) */
.mnb-service-title{
  margin:0; flex:1 1 auto; display:flex; align-items:center; gap:.65rem;
  font-weight:900; letter-spacing:-.01em; font-size: clamp(1.18rem, 1rem + .75vw, 1.45rem);
  line-height:1.25; min-height:48px; padding-block:4px; overflow:visible;
}


.mnb-service-title .mnb-service-ico{ width:24px; height:24px; fill:currentColor; display:block; }



/* Category pill */
.mnb-service-cat{
  margin-left:auto; font-size:.72rem; font-weight:900; border:1px solid color-mix(in srgb, var(--mnb-navy) 18%, var(--mnb-line));
  padding:.22rem .52rem; border-radius:999px; background:#fff; color:color-mix(in srgb, var(--mnb-navy) 88%, black)
}



/* Body copy */
.mnb-service-desc{ margin:.2rem 0 .35rem; color: color-mix(in srgb, var(--mnb-ink) 88%, var(--mnb-muted)); line-height: var(--lh-body); font-size: var(--fs-2) }


.mnb-service-ul{ margin:4px 0 8px; padding-left:18px }


.mnb-service-ul li{ margin:2px 0; line-height:1.55 }


.mnb-service-ul li::marker{ color:var(--mnb-navy) }


.mnb-service-kpis{ display:flex; gap:6px; flex-wrap:wrap; margin-top:2px }


.mnb-service-kpi{
  font-size:.75rem; font-weight:900; border:1px solid color-mix(in srgb, var(--mnb-navy) 18%, var(--mnb-line));
  padding:.24rem .56rem; border-radius:999px; background:#fff; color:color-mix(in srgb, var(--mnb-navy) 88%, black)
}



/* Footer CTA */
.mnb-service-foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:10px; padding-top: var(--s-2) }


.mnb-service-cta{
  display:inline-flex; align-items:center; gap:.55rem; font-weight:900; color:var(--mnb-navy);
  border:1px solid var(--mnb-line); padding:.58rem .9rem; border-radius:999px; background:#fff;
  transition: box-shadow .16s ease, transform .16s ease; will-change: transform, box-shadow;
  position: relative; overflow: hidden;
}


.mnb-service-cta:hover{ box-shadow:var(--shadow); transform: translateY(-1px) }


.mnb-service-cta:focus-visible{ outline:3px solid color-mix(in srgb, var(--mnb-aqua) 45%, transparent); outline-offset:2px }


.mnb-service-cta svg{ width:16px; height:16px; fill:currentColor }



/* Shine sweep */
.mnb-service-cta::before{
  content:""; position:absolute; inset:-20%; transform: translateX(-140%) rotate(var(--shine-angle,65deg));
  width: 220px; height: 220px;
  background:
    linear-gradient(to right,
      transparent 0%,
      color-mix(in srgb, #fff 75%, transparent) 40%,
      color-mix(in srgb, #fff 92%, transparent) 50%,
      color-mix(in srgb, #fff 75%, transparent) 60%,
      transparent 100%);
  mix-blend-mode: screen; opacity:.75; pointer-events:none;
  transition: transform .7s cubic-bezier(.2,.7,.2,1);
}


.mnb-service-cta:hover::before,
.mnb-service-cta:focus-visible::before{ transform: translateX(160%) rotate(var(--shine-angle,65deg)); }



/* ---------- Process ---------- */
.mnb-service-h2{ font-size: clamp(1.45rem, 1.1rem + 1.4vw, 1.9rem); margin: 6px 0; font-weight:900; letter-spacing:-.012em }


.mnb-service-center{text-align:center}


.mnb-service-process{ padding: var(--s-5) 0 calc(var(--s-6) - 8px); background:var(--mnb-surface); border-top:1px solid var(--mnb-line) }


.mnb-service-steps{ display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap: var(--s-3); margin-top: var(--s-3) }


@media (max-width:980px){ .mnb-service-steps{ grid-template-columns:repeat(2,1fr) } }


@media (max-width:560px){ .mnb-service-steps{ grid-template-columns:1fr } }


.mnb-service-step{
  background:var(--mnb-surface); border:1px solid var(--mnb-line); border-radius:14px; padding:14px;
  box-shadow:var(--shadow); transition: transform .18s ease; will-change: transform;
}


.mnb-service-step:hover{ transform: translateY(-2px) }


.mnb-service-step .ico{
  width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:#fff; border:1px solid var(--mnb-line);
  box-shadow:var(--shadow);
}


.mnb-service-step h3{ margin:8px 0 4px; font-size:1rem }


.mnb-service-step p{ margin:0; color:var(--mnb-muted); line-height:1.55 }



/* ---------- FAQ ---------- */
.mnb-service-faq{ padding: var(--s-5) 0 var(--s-6) }


.mnb-service-faq-grid{ display:grid; grid-template-columns:1fr 1fr; gap: var(--s-3) }


@media (max-width:980px){ .mnb-service-faq-grid{ grid-template-columns:1fr } }


.mnb-service-faq details{
  border-radius:14px; padding:14px 16px; background:var(--mnb-surface); border:1px solid var(--mnb-line); box-shadow:var(--shadow);
  transition: box-shadow .16s ease, transform .16s ease;
}


.mnb-service-faq details[open]{ box-shadow: var(--shadow-2); transform: translateY(-1px) }


.mnb-service-faq summary{
  cursor:pointer; font-weight:800; color:var(--mnb-ink); list-style:none; position:relative; padding-right:24px; font-size: var(--fs-2)
}


.mnb-service-faq summary::-webkit-details-marker{ display:none }


.mnb-service-faq summary::after{
  content:""; position:absolute; right:6px; top:50%; width:10px; height:10px;
  border-right:2px solid currentColor; border-bottom:2px solid currentColor;
  transform:translateY(-50%) rotate(-45deg); transition:transform .2s ease
}


.mnb-service-faq details[open] summary::after{ transform:translateY(-50%) rotate(45deg) }


.mnb-service-faq p{ margin:.55rem 0 0; color: color-mix(in srgb, var(--mnb-ink) 82%, var(--mnb-muted)); line-height:1.6 }



/* ---------- Reveal on scroll ---------- */
.mnb-service-reveal{ opacity:0; transform: translateY(10px); }


.mnb-service-reveal.is-in{ opacity:1; transform:none; transition: opacity .46s ease, transform .46s cubic-bezier(.2,.7,.2,1); }


.mnb-service-card.mnb-service-reveal{ transition-delay: .02s }


.mnb-service-card.mnb-service-reveal:nth-child(2){ transition-delay: .05s }


.mnb-service-card.mnb-service-reveal:nth-child(3){ transition-delay: .08s }



/* Motion safety */
@media (prefers-reduced-motion: reduce){
  .mnb-service-chip, .mnb-service-card, .mnb-service-cta, .mnb-service-step, .mnb-service-faq details,
  .mnb-service-reveal, .mnb-service-media img{
    transition: none !important; animation: none !important;
  }
}



/* Small-screen boost */
@media (max-width: 640px){
  .mnb-service-root{ --fs-2: clamp(1.18rem, 1.08rem + 1vw, 1.28rem); --lh-body: 1.75; }
  .mnb-service-content{ padding: 18px 18px 22px; }
}


/* ===================== PROCESS (v2) ===================== */
.mnb-process{
  padding: var(--s-5) 0 calc(var(--s-6) - 6px);
  background: var(--mnb-surface);
  border-top: 1px solid var(--mnb-line);
  position: relative;
  isolation: isolate;
}



/* subtle dotted backdrop */
.mnb-process::before{
  content:"";
  position:absolute; inset:auto 0 -12% 0; height: 240px;
  background-image: radial-gradient(color-mix(in srgb, var(--mnb-line) 75%, transparent) 1px, transparent 1px);
  background-size: 14px 14px; opacity:.65; pointer-events:none; z-index:-1;
}



/* steps grid with connecting line */
.mnb-steps{
  --gap: clamp(14px, 1.8vw, 22px);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--gap);
  list-style: none;
  margin: var(--s-3) 0 0;
  padding: 0;
  position: relative;
}



/* connecting gradient line across the grid */
.mnb-steps::before{
  content:"";
  position:absolute; left: calc(44px + 8px); right: 0; top: 26px; height: 2px;
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--mnb-green) 55%, #fff),
    color-mix(in srgb, var(--mnb-aqua) 55%, #fff));
  opacity:.55; pointer-events:none;
}


@media (max-width:980px){ .mnb-steps{ grid-template-columns: repeat(2,1fr); } }


@media (max-width:560px){
  .mnb-steps{ grid-template-columns: 1fr; }
  .mnb-steps::before{ /* turn the connector into a vertical line on mobile */
    left: 24px; right:auto; width:2px; height: calc(100% - 24px); top: 24px;
    background: linear-gradient(180deg,
      color-mix(in srgb, var(--mnb-green) 55%, #fff),
      color-mix(in srgb, var(--mnb-aqua) 55%, #fff));
  }
}



/* step card */
.mnb-step{
  position: relative;
  background: var(--mnb-surface);
  border: 1px solid var(--mnb-line);
  border-radius: 14px;
  padding: 14px 14px 16px 14px;
  box-shadow: var(--shadow);
  transition: transform .18s var(--mnb-ease), box-shadow .18s var(--mnb-ease);
  display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start;
}


.mnb-step:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-2);
}



/* numbered badge */
.mnb-step-badge{
  width: 44px; height: 44px;
  border-radius: 12px;
  display: grid; place-items: center;
  font-weight: 900;
  color: var(--mnb-navy);
  background:
    linear-gradient(180deg, #fff, #fff) padding-box,
    conic-gradient(from 180deg,
      color-mix(in srgb, var(--mnb-green) 28%, #fff),
      color-mix(in srgb, var(--mnb-aqua) 24%, #fff)) border-box;
  border: 1px solid transparent;
  box-shadow: var(--shadow);
  position: relative;
}


.mnb-step:hover .mnb-step-badge{
  animation: mnb-step-spin 1.2s linear infinite;
}


@keyframes mnb-step-spin{ to { transform: rotate(1turn); } }



/* content */
.mnb-step-title{
  margin: 2px 0 4px; font-size: 1rem; font-weight: 800;
  font-family: var(--mnb-font-heading);
}


.mnb-step-copy{
  margin: 0; color: var(--mnb-muted); line-height: 1.55;
}



/* focus-visible for accessibility */
.mnb-step:focus-within{
  outline: 3px solid color-mix(in srgb, var(--mnb-aqua) 40%, transparent);
  outline-offset: 2px;
}



/* small tweaks on compact screens */
@media (max-width:640px){
  .mnb-step{ padding: 12px; grid-template-columns: auto 1fr; }
  .mnb-step-badge{ width: 40px; height: 40px; border-radius: 10px; }
}



/* motion safety */
@media (prefers-reduced-motion: reduce){
  .mnb-step,
  .mnb-step-badge{ animation: none !important; transition: none !important; }
}


/* ===================== FAQ (v2) ===================== */
.mnb-faq{
  padding: var(--s-5) 0 var(--s-6);
  position: relative;
  isolation: isolate;
}



.mnb-faq-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-3);
  margin-top: var(--s-3);
}


@media (max-width:980px){ .mnb-faq-grid{ grid-template-columns: 1fr; } }



/* Item container with gradient border & shadow */
.mnb-faq-item{
  border-radius: 14px;
  background:
    linear-gradient(var(--mnb-surface), var(--mnb-surface)) padding-box,
    conic-gradient(from 180deg,
      color-mix(in srgb, var(--mnb-green) 20%, #fff),
      color-mix(in srgb, var(--mnb-aqua) 18%, #fff),
      color-mix(in srgb, var(--mnb-navy) 16%, #fff),
      color-mix(in srgb, var(--mnb-green) 20%, #fff)) border-box;
  border: 1px solid transparent;
  box-shadow: var(--shadow);
  transition: box-shadow .18s var(--mnb-ease), transform .18s var(--mnb-ease);
  overflow: hidden;
}


.mnb-faq-item[open]{ box-shadow: var(--shadow-2); transform: translateY(-2px); }



/* Inner hairline */
.mnb-faq-item::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  border-radius: 13px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--mnb-line) 82%, transparent);
  opacity:.9;
}



/* Summary (question row) */
.mnb-faq-q{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
  font-weight: 800;
  color: var(--mnb-ink);
  font-size: var(--fs-2);
}


.mnb-faq-q::-webkit-details-marker{ display:none; }



/* Chevron */
.mnb-faq-chev{
  width: 18px !important; height: 18px !important; flex: 0 0 18px;
  transition: transform .2s var(--mnb-ease);
  color: color-mix(in srgb, var(--mnb-navy) 82%, black);
}


.mnb-faq-item[open] .mnb-faq-chev{ transform: rotate(180deg); }



/* Answer (animated open) */
.mnb-faq-a{
  padding: 0 16px 14px 16px;
  color: color-mix(in srgb, var(--mnb-ink) 82%, var(--mnb-muted));
  line-height: 1.6;
  display: grid;
  grid-template-rows: 0fr;             /* collapsed */
  transition: grid-template-rows .28s var(--mnb-ease), opacity .2s var(--mnb-ease);
  opacity: .0;
}


.mnb-faq-item[open] .mnb-faq-a{
  grid-template-rows: 1fr;             /* expanded */
  opacity: 1;
}


.mnb-faq-a > *{ overflow: hidden; }



/* Hover affordance */
.mnb-faq-item:hover .mnb-faq-q{
  background: linear-gradient(180deg, rgba(0,0,0,.02), transparent);
}



/* Focus visibility for keyboard users */
.mnb-faq-item:focus-within{
  outline: 3px solid color-mix(in srgb, var(--mnb-aqua) 40%, transparent);
  outline-offset: 2px;
}



/* Motion safety */
@media (prefers-reduced-motion: reduce){
  .mnb-faq-item,
  .mnb-faq-chev,
  .mnb-faq-a{ transition: none !important; }
}


/* ---------- Headline underline (animated) ---------- */
.mnb-headline-underline{
  position: relative;
  display: inline-block;
  padding-bottom: .25rem;
}


.mnb-headline-underline::after{
  content:"";
  position:absolute; left:0; right:0; bottom:-2px; height:3px;
  background: linear-gradient(90deg, var(--mnb-green), var(--mnb-aqua));
  border-radius: 999px;
  transform-origin: left;
  transform: scaleX(.12);
  opacity:.85;
  transition: transform .6s var(--mnb-ease), opacity .6s var(--mnb-ease);
}


.mnb-service-pagehead .is-in .mnb-headline-underline::after,
.mnb-headline-underline:hover::after{
  transform: scaleX(1); opacity:1;
}



/* ---------- Filters: scrollable row + indicator ---------- */
.mnb-filters-wrap{
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  margin: var(--s-2) 0 var(--s-3);
  padding: 6px;                      /* room for rail glow */
  border-radius: 14px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}


.mnb-filters-wrap::-webkit-scrollbar{ height: 8px }


.mnb-filters-wrap::-webkit-scrollbar-thumb{
  background: color-mix(in srgb, var(--mnb-navy) 16%, transparent);
  border-radius: 999px;
}



/* light rail behind chips */
.mnb-filters-rail{
  position:absolute; inset: 0 6px;
  border-radius: 12px;
  background: none !important;
  z-index: 0;
  pointer-events: none;
}



/* selection pill that animates under active chip */
.mnb-filter-indicator{
  --x: 6px;         /* set via JS */
  --w: 0px;         /* set via JS */
  position:absolute; top: 8px; left: 0;
  height: calc(100% - 16px);
  width: var(--w);
  transform: translateX(var(--x));
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--mnb-green) 16%, #fff),
    color-mix(in srgb, var(--mnb-aqua) 14%, #fff));
  border: 1px solid var(--mnb-line);
  border-radius: 999px;
  z-index: 1;
  transition: transform .28s var(--mnb-ease), width .28s var(--mnb-ease);
}



/* upgraded chip look */
.mnb-service-chip{
  position: relative;
  z-index: 2; /* above indicator */
  display:inline-flex; align-items:center; gap:.55rem;
  padding: .6rem 1rem;
  scroll-snap-align: start;
  border-radius: 999px;
  font-weight: 800;
  background: #fff;
  border: 1px solid var(--mnb-line);
  color: color-mix(in srgb, var(--mnb-navy) 88%, black);
  box-shadow: var(--shadow);
  transition: transform .16s var(--mnb-ease), box-shadow .16s var(--mnb-ease), color .16s var(--mnb-ease);
  white-space: nowrap;
}


.mnb-service-chip:hover{ transform: translateY(-1px); box-shadow: var(--shadow-2); }



/* icon sizing (prevents global svg rules from blowing up) */
.mnb-service-chip .mnb-chip-ico{
  width: 16px !important; height: 16px !important; flex: 0 0 16px; aspect-ratio: 1/1;
  opacity:.9;
}



/* active state (text only; background handled by indicator) */
.mnb-service-chip.is-active{
  color: var(--mnb-navy);
}



/* compact on small devices */
@media (max-width: 640px){
  .mnb-service-chip{ padding: .52rem .9rem; }
  .mnb-service-pagehead .mnb-service-sub{ margin-top: 2px; }
}

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Poppins:wght@600;700&display=swap");

/* ====== Tokens ====== */
:root{
  color-scheme: light dark;
  --ink:#0b1422; --muted:#516586;
  --navy:#2c4c75; --green:#59b53b; --aqua:#00cfff;
  --bg:#f6f8fb; --surface:#ffffff; --line:#e6eef6;
  --r:18px; --r-sm:12px;
  --s1: clamp(8px,.6vw,10px); --s2: clamp(12px,.9vw,14px); --s3: clamp(16px,1.2vw,18px);
  --s4: clamp(22px,1.8vw,26px); --s5: clamp(30px,2.6vw,40px); --s6: clamp(42px,3.4vw,56px);
  --shadow: 0 8px 22px rgba(15,25,40,.08);
  --shadow2: 0 22px 48px rgba(15,25,40,.14);
  --ease: cubic-bezier(.2,.7,.2,1);
  --container: 1100px;
  --font-sans: "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --font-head: "Poppins", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}



/* Dark scheme tuning */
@media (prefers-color-scheme: dark){
  :root{ --bg:#0e1522; --surface:#121b2b; --line:#203049; --ink:#eef4ff; --muted:#b9c7df; --shadow:none; --shadow2:none; }
}



/* ====== Global overflow & box model (avoid stray scrollbars) ====== */
html, body{ max-width:100%; overflow-x:hidden; }


*, *::before, *::after{ box-sizing:border-box; }



/* ====== Enhanced Background (angled gradient + noise) ====== */
.svc-root{
  font-family: var(--font-sans);
  color: var(--ink);
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--navy) 6%, var(--bg)),
      color-mix(in srgb, var(--aqua) 8%, var(--bg)) 42%,
      color-mix(in srgb, var(--green) 8%, var(--bg)) 100%),
    var(--bg);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/></filter><rect width='120' height='120' filter='url(%23n)' opacity='0.06'/></svg>");
  background-blend-mode: overlay;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  position: relative;
  isolation: isolate;
}



/* background-attachment: fixed only on large screens to avoid nested scroll layers */
@media (min-width:1200px){ .svc-root{ background-attachment: fixed; } }


@media (max-width:1199.98px){ .svc-root{ background-attachment: scroll; } }



/* ====== Decorative blobs — FIXED so they never affect document height ====== */
.svc-root::before,
.svc-root::after{
  content:"";
  position: fixed;  /* <-- changed from absolute */
  border-radius:50%;
  filter: blur(80px);
  opacity:.22;
  z-index:0;
  pointer-events:none;
  will-change: transform;
}


.svc-root::before{
  width:520px; height:520px;
  background: var(--aqua);
  top:-140px; left:-180px;
  animation: floatBlob 18s ease-in-out infinite;
}


.svc-root::after{
  width:600px; height:600px;
  background: var(--green);
  bottom:-180px; right:-200px;
  animation: floatBlob 22s ease-in-out infinite reverse;
}


@keyframes floatBlob{ 0%,100%{ transform:translate(0,0) scale(1) } 50%{ transform:translate(28px,-36px) scale(1.08) } }



/* content wrapper stays above */
.svc-root > * { position: relative; z-index: 1; }



.svc-container{ width:min(var(--container),92%); margin-inline:auto; }



/* ====== Breadcrumb ====== */
.svc-breadcrumb{ padding: var(--s2) 0 var(--s1); font-size:.95rem; color: color-mix(in srgb, var(--ink) 75%, var(--muted)); }


.svc-breadcrumb a{ color: var(--navy); font-weight: 700; text-decoration:none; }


.svc-breadcrumb .sep{ opacity:.5; margin: 0 .35rem; }



/* ====== Hero ====== */
.svc-hero{ padding: var(--s5) 0 var(--s4); }


.svc-hero-card{
  display:grid; grid-template-columns: 1.08fr .92fr; gap: clamp(18px, 2.6vw, 28px);
  background:
    radial-gradient(60% 140% at 0% 0%, rgba(0,207,255,.07), transparent 60%),
    radial-gradient(60% 140% at 100% 100%, rgba(89,181,59,.08), transparent 60%),
    var(--surface);
  border:1px solid var(--line); border-radius: clamp(16px, 2vw, 22px);
  box-shadow: var(--shadow); overflow:hidden;
  contain: layout paint; /* localize any visual overflow */
}


@media (max-width: 960px){ .svc-hero-card{ grid-template-columns:1fr } }



.svc-hero-body{ padding: clamp(16px, 2.2vw, 28px) clamp(16px, 2.2vw, 28px) }


.svc-eyebrow{ display:inline-flex; align-items:center; gap:.5rem; font-weight:800; color:var(--navy); font-size: clamp(1rem,.96rem + .3vw,1.08rem) }


.svc-eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--green); box-shadow:0 0 0 3px rgba(89,181,59,.2) }


.svc-title{ font-family: var(--font-head); font-weight:700; letter-spacing:-.018em; margin:.5rem 0 .35rem; line-height:1.12; font-size: clamp(1.9rem,1.4rem + 2.2vw,2.6rem) }


.svc-tagline{ color:var(--muted); font-size: clamp(1.1rem,1.02rem + .8vw,1.28rem); max-width:65ch; margin:.25rem 0 .9rem; line-height:1.6 }


.svc-cta-row{ display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; margin-top:.5rem }


.svc-cta{
  display:inline-flex; align-items:center; gap:.55rem; font-weight:900; color:#fff;
  background: linear-gradient(135deg, var(--navy), color-mix(in srgb, var(--aqua) 40%, var(--navy)));
  border:1px solid rgba(255,255,255,.25); padding:.78rem 1.05rem; border-radius:999px;
  box-shadow: var(--shadow); transition: transform .16s var(--ease), filter .16s var(--ease);
  text-decoration:none;
}


.svc-cta:hover{ transform: translateY(-1px); filter: brightness(1.04) }


.svc-cta svg{ width:16px; height:16px }


.svc-cta--ghost{ color:var(--navy); background:#fff; border:1px solid var(--line); box-shadow:var(--shadow) }


.svc-cta--ghost:hover{ transform: translateY(-1px) }



.svc-hero-media{ background:#eef4ff; min-height:280px; aspect-ratio:16/11; position:relative }


@media (prefers-color-scheme: dark){ .svc-hero-media{ background:#0f1828 } }


.svc-hero-media img{ width:100%; height:100%; object-fit:cover; display:block; transition: transform .35s var(--ease); }


.svc-hero-card:hover .svc-hero-media img{ transform: scale(1.02) }



/* Quick facts row */
.svc-metas{ display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px }


.svc-meta{
  display:grid; grid-template-columns:auto 1fr; gap:8px; align-items:center;
  background:#fff; border:1px solid var(--line); border-radius:999px; padding:.45rem .75rem; box-shadow:var(--shadow);
  color: color-mix(in srgb, var(--navy) 88%, black);
}


.svc-meta i{ width:18px; height:18px; display:grid; place-items:center; }


.svc-meta strong{ font-weight:900; margin-right:.25rem }



/* ====== Sections ====== */
.svc-section{ padding: var(--s5) 0 }


.svc-h2{ font-family: var(--font-head); font-weight:700; letter-spacing:-.012em; font-size: clamp(1.45rem,1.1rem + 1.4vw,1.9rem); margin: 6px 0 10px }


.svc-overview-grid{ display:grid; grid-template-columns: 1.2fr .8fr; gap: clamp(18px,2.6vw,28px) }


@media (max-width:960px){ .svc-overview-grid{ grid-template-columns:1fr } }


.svc-copy{ background:var(--surface); border:1px solid var(--line); border-radius: var(--r); padding: clamp(16px,2vw,24px); box-shadow:var(--shadow); line-height:1.7; color: color-mix(in srgb, var(--ink) 88%, var(--muted)) }



.svc-benefits{ display:grid; gap:10px }


.svc-chip{ display:inline-flex; align-items:center; gap:.5rem; font-weight:800; background:#fff; border:1px solid var(--line); border-radius:999px; padding:.55rem .85rem; color:color-mix(in srgb, var(--navy) 88%, black); box-shadow:var(--shadow) }


.svc-chip svg{ width:16px; height:16px }



/* What You Get */
.svc-features-grid{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: clamp(14px,2.2vw,20px) }


@media (max-width:720px){ .svc-features-grid{ grid-template-columns:1fr } }


.svc-feature{
  position:relative; border-radius: var(--r);
  background:
    linear-gradient(var(--surface), var(--surface)) padding-box,
    conic-gradient(from 180deg,
      color-mix(in srgb, var(--green) 20%, #fff),
      color-mix(in srgb, var(--aqua) 18%, #fff),
      color-mix(in srgb, var(--navy) 16%, #fff),
      color-mix(in srgb, var(--green) 20%, #fff)) border-box;
  border:1px solid transparent; box-shadow:var(--shadow); overflow:hidden;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease);
}


.svc-feature:hover{ transform: translateY(-2px); box-shadow: var(--shadow2); }


.svc-feature::after{ content:""; position:absolute; inset:0; pointer-events:none; border-radius: calc(var(--r) - 1px); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--line) 80%, transparent) }


.svc-feature-body{ display:grid; grid-template-columns:auto 1fr; gap: 12px; padding: 14px 16px; align-items:start }


.svc-badge{
  width:42px; height:42px; border-radius:12px; display:grid; place-items:center; color:var(--navy);
  background:
    linear-gradient(180deg,#fff,#fff) padding-box,
    conic-gradient(from 180deg,
      color-mix(in srgb, var(--green) 28%, #fff),
      color-mix(in srgb, var(--aqua) 24%, #fff)) border-box;
  border:1px solid transparent; box-shadow: var(--shadow);
}


.svc-feature h3{ margin:4px 0 2px; font-size:1rem; font-weight:800; font-family: var(--font-head) }


.svc-feature p{ margin:0; color: var(--muted); line-height:1.55 }



/* Testimonial */
.svc-quote{
  margin-top: var(--s5);
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: clamp(16px, 2.2vw, 28px);
  position: relative;
}


.svc-quote svg{ width:20px; height:20px; opacity:.9 }


.svc-quote blockquote{ margin: 6px 0 10px; font-size: clamp(1.02rem, .96rem + .6vw, 1.22rem); line-height:1.6; color: color-mix(in srgb, var(--ink) 88%, var(--muted)) }


.svc-quote .who{ font-weight:800; color: var(--navy) }


.svc-quote .role{ color: var(--muted) }



/* Sticky mobile dock (primary CTA) */
.svc-dock{
  position: fixed; left: 50%; bottom: 12px; transform: translateX(-50%);
  background: var(--surface); border:1px solid var(--line); box-shadow: var(--shadow2);
  border-radius: 999px; padding: .35rem .45rem; display:none; gap:.5rem; z-index:50;
  max-width: min(560px, calc(100vw - 16px)); /* prevent x-overflow */
}


@media (max-width:740px){ .svc-dock{ display:flex } }



/* CTA band */
.svc-cta-band{
  margin-top: var(--s5);
  background:
    radial-gradient(900px 420px at 100% 110%, rgba(0,207,255,.1), transparent 60%),
    radial-gradient(900px 420px at 0% 0%, rgba(89,181,59,.12), transparent 60%),
    var(--surface);
  border:1px solid var(--line); border-radius: var(--r);
  padding: clamp(18px, 2.4vw, 28px); text-align:center; box-shadow: var(--shadow);
}


.svc-cta-band h3{ margin: 0 0 6px; font-size: clamp(1.2rem, .9rem + 1.4vw, 1.6rem); font-family: var(--font-head) }


.svc-cta-band p{ margin: 0 0 12px; color: var(--muted) }



/* Reveal */
.svc-reveal{ opacity:0; transform: translateY(8px) }


.svc-reveal.is-in{ opacity:1; transform:none; transition: opacity .44s var(--ease), transform .44s var(--ease) }



/* ================= ICON SIZE HOTFIX (scope + pin sizes) ================= */
.svc-root svg, .mnb-service-root svg{ width:auto; height:auto; }


.svc-root .svc-cta svg, .svc-root .svc-chip svg, .svc-root .svc-badge svg, .svc-root .svc-meta i svg, .svc-root .svc-quote > svg{ width:16px;height:16px;flex:0 0 16px; }


.svc-root .svc-title svg{ width:20px;height:20px; }


.mnb-service-root .mnb-service-cta svg{ width:14px; height:14px; }


.mnb-service-root .mnb-chip-ico{         width:14px; height:14px; }


.mnb-service-root .mnb-faq-chev{         width:14px; height:14px; }


.mnb-service-root .mnb-service-title .mnb-service-ico{ width:20px; height:20px; }


.svc-root svg, .mnb-service-root svg{ vector-effect: non-scaling-stroke; }



@media (prefers-reduced-motion: reduce){
  .svc-hero-card, .svc-feature, .svc-cta, .svc-reveal, .svc-hero-media img { transition: none !important; animation: none !important; }
}

/* ===== Global minimal reset (keeps topbar/footer flush) ===== */
html, body { margin: 0; padding: 0; }



/* ===== Tokens ===== */
:root{
  --container: min(1180px, 92vw);
  --nav-h: 72px;
  --s2:12px; --s3:16px; --s4:20px; --s5:28px; --s6:40px; --s7:56px;
  --r:14px; --rl:20px;

  --ink:#0b1422; --muted:#546482; --navy:#27456d; --aqua:#09c7ff;
  --bg:#f5f7fb; --surface:#ffffffea; --line:#e6eef6;
  --shadow: 0 12px 30px rgba(15,25,40,.08), 0 2px 6px rgba(15,25,40,.05);
  --shadow-lg: 0 30px 80px rgba(12,16,28,.18);
  --ease: cubic-bezier(.22,.61,.36,1);

  --g1: radial-gradient(1200px 600px at 10% -10%, rgba(98,160,255,.20), transparent 60%);
  --g2: radial-gradient(900px 520px at 90% 10%, rgba(166,92,246,.18), transparent 60%);
  --g3: radial-gradient(800px 560px at 50% 120%, rgba(9,199,255,.14), transparent 60%);

  --glass: blur(10px) saturate(1.05);
  --gbg: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.58));
  --gbr: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,0)) border-box,
         linear-gradient(180deg, rgba(53,102,255,.28), rgba(9,199,255,.26)) padding-box;

  --ring: 3px solid color-mix(in srgb, var(--aqua) 60%, white);
}


@media (prefers-color-scheme: dark){
  :root{
    --bg:#0e1522; --surface:#0f1626d9; --line:#24344f; --ink:#eef4ff; --muted:#aab9d7;
    --navy:#6aa3ff; --aqua:#33d6ff; --shadow:none; --shadow-lg: 0 30px 80px rgba(0,0,0,.4);
    --gbg: linear-gradient(180deg, rgba(21,28,46,.78), rgba(18,24,40,.66));
    --gbr: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0)) border-box,
           linear-gradient(180deg, rgba(102,153,255,.35), rgba(51,214,255,.28)) padding-box;
  }
}



/* ===== Page background & container (scoped) ===== */
.mnb-testimonials-page{ max-width:100%; overflow-x:hidden; background:var(--bg); color:var(--ink); }


.mnb-testimonials-page::before{
  content:""; position:fixed; inset:-20vh 0 0 0; z-index:-1;
  background: var(--g1), var(--g2), var(--g3); opacity:.9; pointer-events:none;
}


.mnb-testimonials-page .mnb-container{ width:var(--container); margin-inline:auto; padding-inline: clamp(12px,3vw,24px); }


.mnb-testimonials-page main{ margin:0; padding:0; }



/* ===== Page header ===== */
.mnb-testimonials-page .header{
  width: var(--container);
  margin: calc(var(--nav-h) + var(--s4)) auto var(--s6);
  display:grid; gap:14px;
}


.mnb-testimonials-page .header h1{
  margin:0; font-size: clamp(1.4rem, 1.6vw + 1.2rem, 2.1rem); letter-spacing:-.02em;
}


.mnb-testimonials-page .header .sub{ color: var(--muted); max-width: 68ch; }



/* ===== Featured video ===== */
.mnb-testimonials-page .featured{
  width: var(--container); margin: 0 auto var(--s6);
  display:grid; grid-template-columns: repeat(12, 1fr); gap: clamp(14px,2vw,18px);
}


.mnb-testimonials-page .video-card{
  grid-column: span 12; position:relative; overflow:hidden; border-radius: var(--rl);
  border:1px solid transparent; background: var(--gbg); background-clip: padding-box, border-box; border-image: var(--gbr) 1;
  box-shadow: var(--shadow); display:flex; min-height: 260px;
}


@media (min-width:900px){
  .mnb-testimonials-page .video-card{ grid-column: span 12; min-height: 320px; }
}


.mnb-testimonials-page .video-thumb{
  position:relative; flex: 1 1 62%; background:#000; min-height: 260px;
  background-image: var(--poster, none); background-size: cover; background-position: center;
}


.mnb-testimonials-page .video-info{
  flex: 1 1 38%; padding: clamp(16px,2.4vw,22px); display:grid; gap:10px; align-content:center;
}


.mnb-testimonials-page .play-btn{
  position:absolute; inset:auto auto 16px 16px; display:inline-flex; align-items:center; gap:.55rem;
  padding:.75rem 1rem; border-radius:14px; cursor:pointer; border:1px solid var(--line);
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.82));
  font-weight:900; color:#0b1422; box-shadow: 0 12px 26px rgba(0,0,0,.18);
}


@media (prefers-color-scheme: dark){
  .mnb-testimonials-page .play-btn{ background: linear-gradient(180deg, rgba(18,26,44,.95), rgba(18,26,44,.82)); color: var(--ink); }
}


.mnb-testimonials-page .play-btn:focus-visible{ outline: var(--ring); }


.mnb-testimonials-page .play-btn svg{ width:18px; height:18px; }



/* ===== Testimonials grid ===== */
.mnb-testimonials-page .section{
  width: var(--container); margin: 0 auto var(--s7);
  display:grid; grid-template-columns: repeat(12, 1fr); gap: clamp(14px,2vw,18px);
}


.mnb-testimonials-page .card{
  grid-column: span 12;
  position:relative; background: var(--gbg); border:1px solid transparent; border-radius: var(--r);
  background-clip: padding-box, border-box; border-image: var(--gbr) 1; box-shadow: var(--shadow);
  padding: clamp(16px, 2.4vw, 22px); display:grid; gap:12px;
  opacity:0; transform: translateY(10px); transition: transform .22s var(--ease), box-shadow .22s var(--ease), opacity .45s var(--ease);
}


.mnb-testimonials-page .card.in{ opacity:1; transform:none; }


.mnb-testimonials-page .card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-lg); }



@media (min-width:760px){ .mnb-testimonials-page .card{ grid-column: span 6; } }


@media (min-width:1120px){ .mnb-testimonials-page .card{ grid-column: span 4; } }



.mnb-testimonials-page .quote{ color: var(--ink); font-size: 1.02rem; line-height:1.6; }


.mnb-testimonials-page .meta{ display:flex; align-items:center; gap:12px; }



/* Avatar + fallback */
.mnb-testimonials-page .avatar-wrap{
  position:relative; width:44px; height:44px; flex:0 0 auto;
}


.mnb-testimonials-page .avatar{
  position:absolute; inset:0; width:44px; height:44px; border-radius:999px;
  object-fit:cover; border:1px solid var(--line); display:block; background:#fff;
}


.mnb-testimonials-page .avatar-fallback{
  position:absolute; inset:0; width:44px; height:44px; border-radius:999px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; letter-spacing:.02em;
  background: radial-gradient(120% 120% at 30% 20%, color-mix(in srgb, var(--aqua) 30%, white), color-mix(in srgb, var(--navy) 20%, black));
  color:#fff;
}


.mnb-testimonials-page .avatar-wrap:not(.no-img) .avatar-fallback{ display:none; }


.mnb-testimonials-page .avatar-wrap.no-img .avatar{ display:none; }



.mnb-testimonials-page .person{ display:grid; }


.mnb-testimonials-page .person strong{ font-weight:900; }


.mnb-testimonials-page .person span{ color: var(--muted); font-size:.95rem; }



.mnb-testimonials-page .stars{ display:inline-flex; gap:4px; color: #ffbf3a; }


.mnb-testimonials-page .stars svg{ width:16px; height:16px; }



/* ===== Buttons ===== */
.mnb-testimonials-page .btn{
  appearance:none; border:none; cursor:pointer; font-weight:900;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.66rem 1rem; border-radius:12px; text-decoration:none;
}


.mnb-testimonials-page .btn:focus-visible{ outline: var(--ring); outline-offset:2px; }


.mnb-testimonials-page .btn-primary{
  color:#fff; background: linear-gradient(135deg, color-mix(in srgb, var(--navy) 88%, black), color-mix(in srgb, var(--aqua) 42%, var(--navy)));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 10px 24px rgba(50,120,255,.25);
}



/* ===== Modal (video) ===== */
.mnb-testimonials-page .modal{
  position:fixed; inset:0; display:none; align-items:center; justify-content:center;
  background: rgba(10,16,26,.55); z-index:1000; backdrop-filter: blur(2px);
}


.mnb-testimonials-page .modal.open{ display:flex; }


.mnb-testimonials-page .sheet{
  width:min(980px, 96vw); border-radius:18px; border:1px solid transparent;
  background: var(--gbg); background-clip: padding-box, border-box; border-image: var(--gbr) 1;
  box-shadow: var(--shadow-lg); overflow:hidden;
}


.mnb-testimonials-page .sheet-head{ display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid var(--line); }


.mnb-testimonials-page .sheet-body{ position:relative; aspect-ratio: 16/9; background:#000; }


.mnb-testimonials-page .sheet-body iframe{ position:absolute; inset:0; width:100%; height:100%; }



/* ===== Reveal ===== */
.mnb-testimonials-page .reveal{ opacity:0; transform: translateY(12px); transition: transform .22s var(--ease), opacity .45s var(--ease); }


.mnb-testimonials-page .reveal.in{ opacity:1; transform:none; }



/* ===== Motion-reduction ===== */
@media (prefers-reduced-motion: reduce){
  .mnb-testimonials-page .card,
  .mnb-testimonials-page .video-card,
  .mnb-testimonials-page .reveal{ transition:none !important; transform:none !important; }
}

/* =========================================================
   Webzolt — ABOUT PAGE (scoped)
   All classes are prefixed with .mnb-about-page-
   Improvements:
   • Scoped tokens (no leakage to other pages)
   • LCP/CLS-safe images
   • Interactive hover animations (chips, team, values, CTA)
   • FAQ chevrons + focus styles
   • Optional dark mode palette
========================================================= */

/* ====== Scoped theme tokens ====== */
.mnb-about-page-root{
  --mnb-green:#6abd45; --mnb-navy:#2c4c75; --mnb-aqua:#00CFFF;
  --mnb-ink:#122036;  --mnb-muted:#667693;
  --mnb-bg:#F5F7FA;   --mnb-surface:#FFFFFF; --mnb-line:#E8EEF6;

  --mnb-radius:22px; --mnb-r-lg:28px; --mnb-r-xl:34px;
  --mnb-shadow:0 8px 22px rgba(0,0,0,.12);
  --mnb-shadow-2:0 16px 44px rgba(0,0,0,.14);
  --mnb-blur:14px;

  /* spacing scale for rhythm */
  --mnb-space-1: 8px;
  --mnb-space-2: 12px;
  --mnb-space-3: 16px;
  --mnb-space-4: 20px;
  --mnb-space-5: clamp(22px, 2.2vw, 28px);
  --mnb-space-6: clamp(28px, 3vw, 36px);
  --mnb-space-7: clamp(38px, 4vw, 52px);
  --mnb-space-8: clamp(52px, 6vw, 84px);

  --mnb-container: 1200px;
}



/* Optional: dark mode */
@media (prefers-color-scheme: dark){
  .mnb-about-page-root{
    --mnb-bg:#0e1522; --mnb-surface:#121b2b; --mnb-line:#203049;
    --mnb-ink:#e9f1ff; --mnb-muted:#a9bbd8;
    --mnb-shadow:none; --mnb-shadow-2:none;
  }
}



/* ====== Layout & typography ====== */
.mnb-about-page-container{width:min(var(--mnb-container),92%);margin-inline:auto}


.mnb-about-page-center{text-align:center}



.mnb-about-page-eyebrow{
  color:var(--mnb-navy);font-weight:800;letter-spacing:.02em;margin:0 0 var(--mnb-space-2);
  display:inline-flex;gap:.5rem;align-items:center
}


.mnb-about-page-eyebrow .dot{width:8px;height:8px;border-radius:999px;background:var(--mnb-green);display:inline-block}



.mnb-about-page-h1{
  font-size:clamp(2.25rem,3.6vw,3.25rem);
  line-height:1.08;margin:var(--mnb-space-2) 0 var(--mnb-space-3);
  color:var(--mnb-ink);letter-spacing:-.015em;text-wrap:balance;
}


.mnb-about-page-h2{
  font-size:clamp(2rem,3vw,2.5rem);
  line-height:1.15;margin:0 0 var(--mnb-space-2);color:var(--mnb-ink)
}


.mnb-about-page-h3{
  font-size:clamp(1.35rem,2.2vw,1.6rem);
  line-height:1.25;margin:0 0 var(--mnb-space-2);color:var(--mnb-ink)
}


.mnb-about-page-lead{
  color:var(--mnb-muted);margin:0 0 var(--mnb-space-3);
  font-weight:600;max-width:72ch
}


.mnb-about-page-accent{color:var(--mnb-green)}


.mnb-about-page-muted{color:var(--mnb-muted)}



/* Buttons */
.mnb-about-page-btn{
  display:inline-flex;align-items:center;gap:.6rem;border-radius:999px;
  padding:.78rem 1.12rem;font-weight:800;border:1px solid var(--mnb-line);
  transition:transform .16s ease, box-shadow .16s ease; will-change:transform;
}


.mnb-about-page-btn i{font-size:.95em}


.mnb-about-page-btn-primary{color:#fff;background:linear-gradient(135deg,var(--mnb-green),var(--mnb-aqua));border:0;box-shadow:var(--mnb-shadow)}


.mnb-about-page-btn-outline{color:var(--mnb-navy);background:#fff}


.mnb-about-page-btn:hover{transform:translateY(-1px);box-shadow:var(--mnb-shadow-2)}



/* CTA glow sweep */
.mnb-about-page-btn-primary{position:relative;overflow:hidden}


.mnb-about-page-btn-primary::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);
  transform:translateX(-100%);
}


.mnb-about-page-btn-primary:hover::after{animation:mnb-about-page-btn-shine 1s forwards}


@keyframes mnb-about-page-btn-shine{100%{transform:translateX(100%)}}



/* =========================================================
   HERO — gradient field + glass chips + soft wave
========================================================= */
.mnb-about-page-hero{
  position:relative; overflow:clip;
  padding:var(--mnb-space-8) 0 0;
  background:
    radial-gradient(1200px 520px at 110% -10%, rgba(0,207,255,.18), transparent 55%),
    radial-gradient(900px 420px at -10% 120%, rgba(106,189,69,.16), transparent 60%),
    linear-gradient(180deg,#ffffff 0%, #F6F9FC 78%, var(--mnb-bg) 100%);
  isolation:isolate;
}


.mnb-about-page-hero-inner{position:relative;max-width:980px;margin:0 auto;text-align:center}


.mnb-about-page-kicker{
  display:inline-flex;align-items:center;gap:.55rem;padding:.46rem .92rem;border-radius:999px;
  background:rgba(44,76,117,.08);border:1px solid rgba(44,76,117,.15);
  color:var(--mnb-navy);font-weight:800;box-shadow:0 8px 20px rgba(18,32,54,.04)
}


.mnb-about-page-hero-sub{margin:0 0 var(--mnb-space-3);color:var(--mnb-muted);max-width:720px;margin-inline:auto;font-weight:600}



.mnb-about-page-hero-chips{
  list-style:none;padding:0;margin:var(--mnb-space-2) 0 var(--mnb-space-3);
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px
}


.mnb-about-page-hero-chips li{
  position:relative;display:inline-flex;align-items:center;gap:.55rem;padding:.6rem .98rem;border-radius:999px;
  color:var(--mnb-ink);font-weight:800;background:rgba(255,255,255,.78);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.7);
  box-shadow:0 10px 26px rgba(18,32,54,.08);overflow:hidden;
  animation:mnb-about-page-float 6.5s ease-in-out infinite;
  transition:transform .25s ease, box-shadow .25s ease;
}


.mnb-about-page-hero-chips li:nth-child(2){animation-delay:.6s}


.mnb-about-page-hero-chips li:nth-child(3){animation-delay:1.2s}


.mnb-about-page-hero-chips li:nth-child(4){animation-delay:1.8s}


@keyframes mnb-about-page-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}



/* chip shine + hover tilt */
.mnb-about-page-hero-chips li::before{
  content:"";position:absolute;left:-120%;top:0;height:100%;width:40%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg);opacity:0;
}


.mnb-about-page-hero-chips li:hover{transform:translateY(-4px) scale(1.04) rotate(-1deg); box-shadow:0 16px 36px rgba(18,32,54,.14)}


.mnb-about-page-hero-chips li:hover::before{animation:mnb-about-page-shine 900ms ease forwards}


@keyframes mnb-about-page-shine{10%{opacity:.65}100%{left:160%;opacity:0}}



.mnb-about-page-btn.mnb-about-page-btn-primary{
  background-size:200% 100%;
  background-image:linear-gradient(135deg,var(--mnb-green) 0%, var(--mnb-aqua) 100%);
  box-shadow:0 12px 28px rgba(0,207,255,.18),0 8px 18px rgba(106,189,69,.14)
}


.mnb-about-page-btn.mnb-about-page-btn-primary:hover{background-position:100% 0%;transform:translateY(-2px)}



.mnb-about-page-wave{display:block;width:100%;height:auto;margin-top:var(--mnb-space-7)}


.mnb-about-page-wave path{fill:var(--mnb-bg)}


.mnb-about-page-h1 .mnb-about-page-accent{
  background:linear-gradient(135deg,var(--mnb-green) 0%, var(--mnb-aqua) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}



/* Focus */
.mnb-about-page-btn:focus-visible,
.mnb-about-page-hero-chips li:focus-within{
  outline:3px solid color-mix(in oklab, var(--mnb-aqua) 60%, white);
  outline-offset:2px;border-radius:999px;
}



/* =========================================================
   INTRO — content-first two-column + tilt shot
========================================================= */
.mnb-about-page-intro{
  position:relative;background:var(--mnb-bg);
  padding:var(--mnb-space-7) 0 var(--mnb-space-8);
  isolation:isolate
}


.mnb-about-page-intro-grid{
  display:grid;grid-template-columns:1.05fr .95fr;
  gap:clamp(24px,3.2vw,52px);align-items:center
}


.mnb-about-page-intro p.mnb-about-page-lead + .mnb-about-page-lead{margin-top:var(--mnb-space-2)}



.mnb-about-page-tilt{perspective:1200px;transform-style:preserve-3d}


.mnb-about-page-shot{
  position:relative;border-radius:var(--mnb-r-lg);overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.87));
  border:1px solid rgba(255,255,255,.85);box-shadow:var(--mnb-shadow-2);
  backdrop-filter:blur(var(--mnb-blur));-webkit-backdrop-filter:blur(var(--mnb-blur));
  transform:translateY(6px);transition:transform .5s ease, box-shadow .4s ease;will-change:transform;
}


.mnb-about-page-shot img{width:100%;height:auto;display:block;transform:translateZ(0.01px)}


.mnb-about-page-shot::before,.mnb-about-page-shot-gloss{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:soft-light}


.mnb-about-page-shot::before{
  background:
    radial-gradient(520px 240px at 18% 16%, rgba(0,207,255,.12), transparent 56%),
    radial-gradient(520px 240px at 82% 84%, rgba(106,189,69,.10), transparent 58%);
  transform:translateZ(12px);
}


.mnb-about-page-shot-gloss{
  background:linear-gradient(160deg, rgba(255,255,255,.22) 0%, transparent 40% 80%, rgba(255,255,255,.12) 100%);
  transform:translateZ(18px)
}


@media (hover:hover){
  .mnb-about-page-shot:hover{transform:rotateX(4deg) rotateY(-4deg) translateY(-2px);box-shadow:0 24px 52px rgba(18,32,54,.18)}
  .mnb-about-page-shot:hover::before{transform:translateZ(24px) translate(-2px,-2px)}
  .mnb-about-page-shot:hover .mnb-about-page-shot-gloss{transform:translateZ(34px) translate(2px,2px)}
}



/* small stat card spacing (if you want to add one) */
.mnb-about-page-stat{
  position:absolute;left:6%;bottom:-10%;
  min-width:220px;padding:16px 18px;border-radius:22px;
  background:linear-gradient(135deg,var(--mnb-green),var(--mnb-aqua));
  color:#fff;box-shadow:var(--mnb-shadow-2)
}


.mnb-about-page-stat .n{display:block;font-weight:900;font-size:clamp(1.2rem,2.2vw,1.6rem);line-height:1}



/* =========================================================
   Vision/Mission/Promise — gradient cards
========================================================= */
.mnb-about-page-vm{background:#fff;padding:var(--mnb-space-8) 0}


.mnb-about-page-vm-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:var(--mnb-space-5)
}


.mnb-about-page-card{
  border-radius:var(--mnb-radius); padding:clamp(18px,2.2vw,22px);
  background:
    linear-gradient(#fff,#fff) padding-box,
    conic-gradient(from 180deg, rgba(106,189,69,.22), rgba(44,76,117,.22)) border-box;
  border:1px solid transparent; box-shadow:var(--mnb-shadow);
  transition:transform .18s ease, box-shadow .18s ease;
}


.mnb-about-page-card:hover{transform:translateY(-2px);box-shadow:var(--mnb-shadow-2)}


.mnb-about-page-card-badge{
  width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:12px;
  background:linear-gradient(135deg,rgba(106,189,69,.18),rgba(0,207,255,.2));color:var(--mnb-navy)
}


.mnb-about-page-card h3{margin:.25rem 0 .35rem}


.mnb-about-page-card p{margin:0;color:var(--mnb-ink);line-height:1.6}



/* =========================================================
   Values — richer cards with descriptions + hover pulse
========================================================= */
.mnb-about-page-values{background:var(--mnb-bg);padding:var(--mnb-space-8) 0}


.mnb-about-page-values-grid{
  list-style:none;padding:0;margin:var(--mnb-space-5) 0 0;
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--mnb-space-5)
}


.mnb-about-page-value{
  display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:.75rem;
  background:#fff;border:1px solid var(--mnb-line);border-radius:18px;padding:16px 18px;box-shadow:var(--mnb-shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}


.mnb-about-page-value:hover{transform:translateY(-4px);box-shadow:0 20px 36px rgba(18,32,54,.14)}


.mnb-about-page-value .mnb-about-page-icon{
  width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,rgba(106,189,69,.12),rgba(0,207,255,.12));color:var(--mnb-navy);
  transition:transform .25s ease;
}


.mnb-about-page-value:hover .mnb-about-page-icon{animation:mnb-about-page-icon-bounce .6s ease}


@keyframes mnb-about-page-icon-bounce{
  30%{transform:scale(1.15) rotate(-6deg)}
  60%{transform:scale(.9) rotate(6deg)}
  100%{transform:none}
}


.mnb-about-page-value h4{margin:0;font-size:1.05rem;line-height:1.25;color:var(--mnb-ink);font-weight:800}


.mnb-about-page-value p{grid-column:1/-1;margin:.45rem 0 0;color:var(--mnb-muted);font-weight:500;line-height:1.6}



/* =========================================================
   Team — short hero + grid + tilt hover
========================================================= */
.mnb-about-page-team-hero{background:#fff;padding:var(--mnb-space-8) 0 var(--mnb-space-7)}


.mnb-about-page-team-hero-grid{
  display:grid;grid-template-columns:1.15fr .85fr;gap:var(--mnb-space-6);align-items:center
}


.mnb-about-page-illustration img{
  max-width:400px;width:100%;height:auto;display:block;margin-inline:auto;
  filter:drop-shadow(0 14px 28px rgba(0,0,0,.12))
}


.mnb-about-page-team-gridwrap{
  background:#F0F3F8;border-top:1px solid var(--mnb-line);border-bottom:1px solid var(--mnb-line);
  padding:var(--mnb-space-8) 0
}


.mnb-about-page-team-grid{
  list-style:none;padding:0;margin:var(--mnb-space-5) 0 0;
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--mnb-space-5)
}


.mnb-about-page-team-card{
  background:#fff;border:1px solid var(--mnb-line);border-radius:var(--mnb-radius);
  padding:18px;text-align:center;box-shadow:var(--mnb-shadow);
  perspective:800px;transform-style:preserve-3d;
  transition:transform .35s ease, box-shadow .35s ease;
  will-change:transform;
}


.mnb-about-page-team-card:hover{
  transform:rotateX(4deg) rotateY(-3deg) translateY(-4px);
  box-shadow:0 20px 48px rgba(18,32,54,.18);
}


.mnb-about-page-avatar{width:96px;height:96px;margin:0 auto 10px;border-radius:50%;overflow:hidden;background:rgba(44,76,117,.06);display:grid;place-items:center}


.mnb-about-page-avatar img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:1/1}


.mnb-about-page-team-name{margin:.2rem 0 0;color:var(--mnb-ink);font-size:1.04rem;font-weight:800}


.mnb-about-page-team-role{margin:.15rem 0 .6rem;color:var(--mnb-muted)}


.mnb-about-page-socials a{display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid var(--mnb-line);border-radius:10px;color:var(--mnb-navy);transition:transform .18s ease, box-shadow .18s ease}


.mnb-about-page-socials a + a{margin-left:6px}


.mnb-about-page-socials a:hover{transform:translateY(-1px);box-shadow:var(--mnb-shadow)}



/* =========================================================
   FAQ — accessible details with chevrons + focus ring
========================================================= */
.mnb-about-page-faq{background:#fff;padding:var(--mnb-space-8) 0 var(--mnb-space-8)}


.mnb-about-page-faq-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:var(--mnb-space-5)
}


.mnb-about-page-faq details{
  border-radius:18px;padding:16px 18px;background:#fff;border:1px solid var(--mnb-line);box-shadow:var(--mnb-shadow);
  transition:background .2s ease, border-color .2s ease
}


.mnb-about-page-faq summary{
  cursor:pointer;font-weight:800;color:var(--mnb-ink);list-style:none;outline:none;
  position:relative; padding-right:28px;
}


.mnb-about-page-faq summary::-webkit-details-marker{display:none}


.mnb-about-page-faq summary::after{
  content:""; position:absolute; right:6px; top:50%; width:10px; height:10px;
  border-right:2px solid var(--mnb-ink); border-bottom:2px solid var(--mnb-ink);
  transform:translateY(-50%) rotate(-45deg); transition:transform .25s ease;
}


.mnb-about-page-faq details[open] summary::after{ transform:translateY(-50%) rotate(45deg) }


.mnb-about-page-faq details[open]{
  background:linear-gradient(0deg, rgba(0,207,255,.06), rgba(106,189,69,.06)), #fff;
  border-color:color-mix(in oklab, var(--mnb-aqua) 35%, var(--mnb-line));
}


.mnb-about-page-faq summary:focus-visible{
  outline:3px solid color-mix(in oklab,var(--mnb-aqua) 60%,white); border-radius:8px;
}


.mnb-about-page-faq p{margin:.65rem 0 0;color:var(--mnb-ink);line-height:1.6}



/* ====== Reveal & stagger ====== */
.mnb-about-page-reveal{opacity:0;transform:translateY(14px);transition:opacity .5s ease, transform .5s ease;transition-delay:var(--delay,0ms)}


.mnb-about-page-reveal.mnb-about-page-is-in{opacity:1;transform:none}


.no-js .mnb-about-page-reveal{opacity:1;transform:none}



/* Motion safety */
@media (prefers-reduced-motion: reduce){
  .mnb-about-page-reveal{opacity:1;transform:none}
  .mnb-about-page-btn, .mnb-about-page-team-card{transition:none}
  .mnb-about-page-tilt{perspective:none}
  .mnb-about-page-shot, .mnb-about-page-shot::before, .mnb-about-page-shot-gloss{transform:none!important;transition:none!important}
  .mnb-about-page-hero-chips li{animation:none}
}



/* ====== Responsive ====== */
@media (max-width:1100px){
  .mnb-about-page-intro-grid{align-items:start}
}


@media (max-width:1024px){
  .mnb-about-page-intro-grid{grid-template-columns:1fr}
  .mnb-about-page-shot{max-width:760px;margin-inline:auto}
  .mnb-about-page-stat{position:relative;left:auto;bottom:auto;margin-top:12px}
  .mnb-about-page-team-hero-grid{grid-template-columns:1fr}
  .mnb-about-page-team-grid{grid-template-columns:repeat(3,1fr)}
  .mnb-about-page-faq-grid{grid-template-columns:1fr}
  .mnb-about-page-vm-grid{grid-template-columns:1fr 1fr}
  .mnb-about-page-values-grid{grid-template-columns:1fr 1fr}
}


@media (max-width:680px){
  .mnb-about-page-team-grid{grid-template-columns:repeat(2,1fr)}
}


@media (max-width:520px){
  .mnb-about-page-team-grid{grid-template-columns:1fr}
  .mnb-about-page-vm-grid{grid-template-columns:1fr}
  .mnb-about-page-values-grid{grid-template-columns:1fr}
}

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&family=Poppins:wght@700;800&display=swap");

/* ===== Tokens ===== */
:root{
  --mp-ink:#0b1422; --mp-muted:#516586;
  --mp-navy:#2c4c75; --mp-green:#59b53b; --mp-aqua:#00cfff;
  --mp-bg:#f6f8fb; --mp-surface:rgba(255,255,255,.78); --mp-line:#e6eef6;
  --mp-r:18px; --mp-rs:12px;
  --mp-s1: clamp(8px,.6vw,10px); --mp-s2: clamp(12px,.9vw,14px); --mp-s3: clamp(16px,1.2vw,18px);
  --mp-s4: clamp(22px,1.8vw,26px); --mp-s5: clamp(30px,2.6vw,40px); --mp-s6: clamp(42px,3.4vw,56px);
  --mp-shadow: 0 8px 22px rgba(15,25,40,.08);
  --mp-shadow2: 0 22px 48px rgba(15,25,40,.14);
  --mp-ease: cubic-bezier(.2,.7,.2,1);
  --mp-container: 1180px;
  --mp-font: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --mp-head: "Poppins", Segoe UI, Roboto, Helvetica, Arial, sans-serif;

  /* NEW: icon sizing + sticky offset */
  --mp-ico: 16px;
  --mp-ico-sm: 14px;
  --mp-sticky-top: 64px; /* adjust if your header height differs */
}


@media (prefers-color-scheme: dark){
  :root{ --mp-bg:#0e1522; --mp-surface:rgba(18,27,43,.78); --mp-line:#203049; --mp-ink:#eef4ff; --mp-muted:#b9c7df; --mp-shadow:none; --mp-shadow2:none; }
}



/* ===== Global overflow ===== */
html, body{ max-width:100%; overflow-x:hidden; }



/* ===== Background ===== */
.mnb-portfolio-root{
  font-family: var(--mp-font); color:var(--mp-ink);
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--mp-navy) 6%, var(--mp-bg)),
      color-mix(in srgb, var(--mp-aqua) 8%, var(--mp-bg)) 42%,
      color-mix(in srgb, var(--mp-green) 8%, var(--mp-bg)) 100%),
    var(--mp-bg);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/></filter><rect width='120' height='120' filter='url(%23n)' opacity='0.06'/></svg>");
  background-blend-mode: overlay;
  position: relative; isolation: isolate;
}


@media (min-width:1200px){ .mnb-portfolio-root{ background-attachment: fixed; } }


.mnb-portfolio-root::before,
.mnb-portfolio-root::after{
  content:""; position:fixed; border-radius:50%; filter:blur(80px); opacity:.22; z-index:0; pointer-events:none;
}


.mnb-portfolio-root::before{ width:520px;height:520px;background:var(--mp-aqua);top:-140px;left:-180px; animation:mpFloat 18s ease-in-out infinite; }


.mnb-portfolio-root::after{  width:600px;height:600px;background:var(--mp-green);bottom:-180px;right:-200px; animation:mpFloat 22s ease-in-out infinite reverse; }


@keyframes mpFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(28px,-36px) scale(1.08)}}


.mnb-portfolio-root > * { position:relative; z-index:1 }



/* ===== Layout ===== */
.mnb-portfolio-container{ width:min(var(--mp-container),92%); margin-inline:auto; }



/* ===== Breadcrumb ===== */
.mnb-portfolio-breadcrumb{ padding: var(--mp-s2) 0 var(--mp-s1); font-size:.95rem; color: color-mix(in srgb, var(--mp-ink) 75%, var(--mp-muted)); }


.mnb-portfolio-breadcrumb a{ color:var(--mp-navy); font-weight:800; text-decoration:none; }


.mnb-portfolio-breadcrumb .sep{ opacity:.5; margin:0 .35rem }



/* ===== Hero / Header ===== */
.mnb-portfolio-hero{ padding: var(--mp-s5) 0 var(--mp-s3); }


.mnb-portfolio-title{ font-family:var(--mp-head); font-weight:800; letter-spacing:-.018em; font-size: clamp(2rem,1.4rem + 2.4vw,2.8rem); margin: .2rem 0 .4rem }


.mnb-portfolio-sub{ color:var(--mp-muted); font-size: clamp(1.05rem, 1rem + .6vw, 1.22rem); max-width: 70ch; line-height:1.6 }



/* ===== Sticky Controls (glass) ===== */
.mnb-portfolio-sticky{
  position: sticky; top: var(--mp-sticky-top); z-index: 5;
  margin-top: 8px; padding: 10px; border-radius: 16px;
  background: var(--mp-surface); border:1px solid color-mix(in srgb, var(--mp-line) 88%, transparent);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: var(--mp-shadow);
}


.mnb-portfolio-controls{
  display:grid; grid-template-columns: 1fr; grid-template-rows: auto auto;
  gap:10px; align-items:center;
}



/* Search */
.mnb-portfolio-search{ display:flex; align-items:center; gap:.55rem; padding:.7rem .9rem; border-radius:999px; background:#fff; border:1px solid var(--mp-line); box-shadow:var(--mp-shadow); }


.mnb-portfolio-search input{ all:unset; flex:1; font-size:1rem; color:var(--mp-ink); min-width:160px; }



/* Chips scroller */
.mnb-portfolio-chips{
  display:flex; gap:8px; overflow:auto; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; padding:4px;
  mask-image: linear-gradient(90deg, transparent 0, black 24px, black calc(100% - 24px), transparent 100%);
}


.mnb-portfolio-chip{ scroll-snap-align: start; display:inline-flex; align-items:center; gap:.45rem; padding:.58rem .9rem; border-radius:999px; font-weight:800; background:#fff; border:1px solid var(--mp-line); box-shadow:var(--mp-shadow); color: color-mix(in srgb, var(--mp-navy) 88%, black); cursor:pointer; user-select:none; white-space:nowrap; }


.mnb-portfolio-chip[data-active="1"]{ background: linear-gradient(135deg, var(--mp-navy), color-mix(in srgb,var(--mp-aqua) 40%, var(--mp-navy))); color:#fff; border-color: transparent; }



/* ===== Toolbar (between sticky and grid) ===== */
.mnb-portfolio-toolbar{
  margin: 12px auto 6px;
  width: min(var(--mp-container), 92%);
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}


.mnb-portfolio-toolbar-left{ display: inline-flex; gap: 6px; }


.mnb-portfolio-toolbar-right{ display: inline-flex; align-items: center; gap: 8px; }


.mnb-portfolio-sortlabel{ font-size:.92rem; font-weight:700; color:var(--mp-muted); }



/* Toggle & Select reuse existing styles */
.mnb-portfolio-toggle{ display:inline-flex; align-items:center; gap:.4rem; padding:.55rem .8rem; border-radius:999px; font-weight:800; background:#fff; border:1px solid var(--mp-line); box-shadow:var(--mp-shadow); color:var(--mp-navy); cursor:pointer; }


.mnb-portfolio-toggle[aria-pressed="true"]{ background: linear-gradient(135deg, var(--mp-navy), color-mix(in srgb,var(--mp-aqua) 40%, var(--mp-navy))); color:#fff; border-color: transparent; }


.mnb-portfolio-select{ appearance:none; -webkit-appearance:none; -moz-appearance:none; padding:.68rem 2.4rem .68rem .9rem; border-radius:999px; border:1px solid var(--mp-line); background: #fff; box-shadow:var(--mp-shadow); font-weight:700; color:var(--mp-navy); }



@media (max-width: 720px){
  .mnb-portfolio-toolbar{ flex-direction: column; align-items: stretch; }
  .mnb-portfolio-toolbar-right{ justify-content: flex-end; }
}



/* ===== Grid & List ===== */
.mnb-portfolio-grid{ margin-top: 18px; display:grid; gap: clamp(14px, 2vw, 20px); grid-template-columns: repeat(12, 1fr); }


@media (max-width:720px){ .mnb-portfolio-grid{ grid-template-columns: repeat(6, 1fr); } }



.mnb-portfolio-card{
  grid-column: span 4; background: #fff; border:1px solid var(--mp-line); border-radius: var(--mp-r); box-shadow: var(--mp-shadow); overflow:hidden; display:flex; flex-direction:column; transition: transform .18s var(--mp-ease), box-shadow .18s var(--mp-ease);
  border: 1px solid color-mix(in srgb, var(--mp-line) 90%, transparent);
  background:
    linear-gradient(#fff,#fff) padding-box,
    linear-gradient(135deg, rgba(44,76,117,.14), rgba(0,207,255,.14)) border-box;
  transform: translateZ(0);
  opacity: 0; transform: translateY(8px);
  animation: mpFadeUp .5s var(--mp-ease) forwards;
}


@media (max-width:1024px){ .mnb-portfolio-card{ grid-column: span 6; } }


@media (max-width:640px){  .mnb-portfolio-card{ grid-column: span 6; } }


.mnb-portfolio-card:is(:hover,:focus-within){ transform: translateY(-2px); box-shadow: var(--mp-shadow2); }



/* Fade-in staggering */
.mnb-portfolio-card:nth-child(1){ animation-delay: .02s }


.mnb-portfolio-card:nth-child(2){ animation-delay: .05s }


.mnb-portfolio-card:nth-child(3){ animation-delay: .08s }


.mnb-portfolio-card:nth-child(4){ animation-delay: .11s }


.mnb-portfolio-card:nth-child(5){ animation-delay: .14s }


.mnb-portfolio-card:nth-child(6){ animation-delay: .17s }


.mnb-portfolio-card:nth-child(7){ animation-delay: .20s }


.mnb-portfolio-card:nth-child(8){ animation-delay: .23s }


@keyframes mpFadeUp{ to{ opacity:1; transform: translateY(0); } }



/* Cover */
.mnb-portfolio-cover{ position:relative; aspect-ratio:16/10; background:#e9eef7; overflow:hidden; }


@media (prefers-color-scheme: dark){ .mnb-portfolio-cover{ background:#0f1828 } }


.mnb-portfolio-img{ width:100%; height:100%; object-fit:cover; display:block; transform:scale(1.02); filter: blur(10px) saturate(.9); opacity:.9; transition: transform .5s var(--mp-ease), filter .5s var(--mp-ease), opacity .5s var(--mp-ease); }


.mnb-portfolio-img.is-loaded{ filter: none; opacity:1; }


.mnb-portfolio-cover .cattag{ position:absolute; left:10px; bottom:10px; display:inline-flex; align-items:center; gap:.45rem; font-weight:900; color:#fff; padding:.44rem .66rem; border-radius:10px; background: linear-gradient(135deg, var(--mp-navy), color-mix(in srgb, var(--mp-aqua) 40%, var(--mp-navy))); box-shadow: 0 6px 16px rgba(0,0,0,.18); }


.mnb-portfolio-grad{ position:absolute; inset:auto 0 0 0; height:50%; background: linear-gradient(180deg, transparent, rgba(0,0,0,.06), rgba(0,0,0,.24)); pointer-events:none }



/* Body */
.mnb-portfolio-body{ padding: 12px 14px 14px 14px; display:flex; flex-direction:column; gap:8px; }


.mnb-portfolio-eyebrow{ display:inline-flex; align-items:center; gap:.4rem; font-weight:900; color:var(--mp-navy); font-size:.92rem }


.mnb-portfolio-title3{ font-family:var(--mp-head); font-size: clamp(1.02rem, .98rem + .4vw, 1.18rem); margin:0; line-height:1.25; letter-spacing:-.01em }


.mnb-portfolio-excerpt{ margin:0; color:var(--mp-muted); line-height:1.55 }



/* Metrics */
.mnb-portfolio-metrics{ display:flex; gap:8px; flex-wrap:wrap; }


.mnb-portfolio-badge{ display:inline-flex; gap:.4rem; align-items:center; padding:.4rem .6rem; border-radius:10px; background:#fff; border:1px solid var(--mp-line); font-size:.88rem; font-weight:800; color: color-mix(in srgb, var(--mp-navy) 88%, black); }



/* CTA */
.mnb-portfolio-cta{ margin-top:4px; display:flex; align-items:center; gap:.5rem; font-weight:900; color:#fff; text-decoration:none; align-self:flex-start; background: linear-gradient(135deg, var(--mp-navy), color-mix(in srgb, var(--mp-aqua) 40%, var(--mp-navy))); border:1px solid rgba(255,255,255,.25); padding:.66rem .9rem; border-radius:999px; box-shadow: var(--mp-shadow); transition: transform .16s var(--mp-ease), filter .16s var(--mp-ease); }


.mnb-portfolio-cta:hover{ transform:translateY(-1px); filter:brightness(1.04) }



/* List view overrides */
.mnb-portfolio-grid[data-view="list"]{ grid-template-columns: repeat(12, 1fr); }


.mnb-portfolio-grid[data-view="list"] .mnb-portfolio-card{ grid-column: 1 / -1; flex-direction:row; align-items:stretch; }


.mnb-portfolio-grid[data-view="list"] .mnb-portfolio-cover{ flex:0 0 36%; min-width:300px; aspect-ratio:auto; }


.mnb-portfolio-grid[data-view="list"] .mnb-portfolio-body{ padding: 16px 18px; }



/* Load more */
.mnb-portfolio-actions{ display:flex; justify-content:center; margin: 18px 0 var(--mp-s5) }


.mnb-portfolio-btn{ appearance:none; border:none; cursor:pointer; padding:.8rem 1.2rem; border-radius:999px; font-weight:900; background:#fff; border:1px solid var(--mp-line); box-shadow:var(--mp-shadow); color:var(--mp-navy); }


.mnb-portfolio-btn[disabled]{ opacity:.6; cursor:not-allowed }



/* Sticky mobile dock */
.mnb-portfolio-dock{ position: fixed; left: 50%; bottom: 12px; transform: translateX(-50%); background: #fff; border:1px solid var(--mp-line); box-shadow: var(--mp-shadow2); border-radius: 999px; padding:.35rem .45rem; display:none; gap:.5rem; z-index:50; max-width: min(560px, calc(100vw - 16px)); }


.mnb-portfolio-dock a{ text-decoration:none; display:inline-flex; align-items:center; gap:.5rem; font-weight:900; color:#fff; background: linear-gradient(135deg, var(--mp-navy), color-mix(in srgb, var(--mp-aqua) 40%, var(--mp-navy))); border:1px solid rgba(255,255,255,.25); padding:.72rem 1rem; border-radius:999px; }


.mnb-portfolio-dock .ghost{ color:var(--mp-navy); background:#fff; border:1px solid var(--mp-line); }


@media (max-width:740px){ .mnb-portfolio-dock{ display:flex } }



/* Back to top */
.mnb-portfolio-top{ position:fixed; right:16px; bottom:20px; z-index:50; display:none; }


.mnb-portfolio-top button{ appearance:none; border:none; cursor:pointer; width:44px; height:44px; border-radius:12px; background:#fff; border:1px solid var(--mp-line); box-shadow:var(--mp-shadow); display:grid; place-items:center; }


.mnb-portfolio-top svg{ width:20px; height:20px; color:var(--mp-navy) }



/* Focus ring */
:where(.mnb-portfolio-root a, .mnb-portfolio-root button, .mnb-portfolio-root input, .mnb-portfolio-root select):focus-visible{ outline: 3px solid color-mix(in srgb, var(--mp-aqua) 50%, white); outline-offset:2px; border-radius:12px }



/* ===== Icon sizing & alignment (FIX) ===== */
.mnb-portfolio-root svg { flex-shrink: 0; vertical-align: middle; }


.mnb-portfolio-root use { vector-effect: non-scaling-stroke; }



/* One place to control all inline icon sizes */
.mnb-portfolio-root .mnb-portfolio-cta svg,
.mnb-portfolio-root .mnb-portfolio-search svg,
.mnb-portfolio-root .mnb-portfolio-chip svg,
.mnb-portfolio-root .mnb-portfolio-toggle svg,
.mnb-portfolio-root .cattag svg {
  width: var(--mp-ico);
  height: var(--mp-ico);
  display:inline-block;
  line-height:0;
  /* nudge into optical center without affecting layout */
  translate: 0 1px;
}



/* Micro-spacing so icons never crowd text */
.mnb-portfolio-search svg { margin-right: .5rem; }


.mnb-portfolio-cta    svg { margin-left:  .5rem; }


.mnb-portfolio-chip   svg,
.mnb-portfolio-toggle svg,
.mnb-portfolio-cover .cattag svg { margin-right: .45rem; }



/* Buttons/chips min height to prevent “tall icon” feel on some DPIs */
.mnb-portfolio-chip,
.mnb-portfolio-toggle,
.mnb-portfolio-search,
.mnb-portfolio-cta { min-height: 40px; }



/* Optional: slightly smaller badge icons inside metrics if you add any later */
.mnb-portfolio-badge svg { width: var(--mp-ico-sm); height: var(--mp-ico-sm); translate: 0 .5px; }



@media (prefers-color-scheme: dark){
  .mnb-portfolio-card{
    background:
      linear-gradient(#141c2e,#141c2e) padding-box,
      linear-gradient(135deg, rgba(0,207,255,.20), rgba(89,181,59,.12)) border-box;
    border-color: rgba(255,255,255,.06);
  }
  .mnb-portfolio-card:is(:hover,:focus-within){ box-shadow: 0 20px 48px rgba(0,0,0,.35); }
}

/* ============== Page tokens / fallbacks ============== */
:root{
  --mnb-container: min(1180px, 92vw);
  --mnb-nav-h: 72px; /* updated by global CSS if present */
  --mnb-s-2: 12px; --mnb-s-3: 16px; --mnb-s-4: 20px; --mnb-s-5: 28px; --mnb-s-6: 40px; --mnb-s-7: 56px;
  --mnb-radius: 12px; --mnb-radius-lg: 18px;
  --mnb-line: #e6eef6; --mnb-surface:#fff; --mnb-ink:#0b1422; --mnb-muted:#516586;
  --mnb-navy:#2c4c75; --mnb-aqua:#00cfff; --mnb-green:#59b53b;
  --mnb-shadow: 0 10px 26px rgba(15,25,40,.08);
  --mnb-shadow2: 0 20px 48px rgba(15,25,40,.14);
}


@media (prefers-color-scheme: dark){
  :root{ --mnb-surface:#141c2e; --mnb-line:#263855; --mnb-ink:#eef4ff; --mnb-muted:#b9c7df; --mnb-shadow:none; --mnb-shadow2:none; }
}



/* ============== Global containment ============== */
html, body { max-width:100%; overflow-x:hidden; }


.mnb-container{ width:var(--mnb-container); margin-inline:auto; padding-inline: clamp(12px, 3vw, 24px); }



/* ============== Breadcrumb ============== */
.mnb-breadcrumb-row{ padding: var(--mnb-s-4) 0 var(--mnb-s-3); }


.mnb-link{ color:var(--mnb-navy); font-weight:800; text-decoration:none; }


.mnb-link:hover{ text-decoration:underline; }


.mnb-muted{ color: var(--mnb-muted); }



/* ============== Hero (glow + subtle motion) ============== */
.mnb-case-hero{ position:relative; margin: var(--mnb-s-4) auto; overflow:hidden; border-radius: var(--mnb-radius-lg);
  border:1px solid color-mix(in srgb, var(--mnb-line) 90%, transparent); background:var(--mnb-surface); box-shadow:var(--mnb-shadow);
}


.mnb-case-hero::before{
  content:""; position:absolute; inset:-20% -10% auto -10%; height:420px; border-radius:50%;
  background: radial-gradient(closest-side, color-mix(in srgb, var(--mnb-aqua) 55%, transparent), transparent 70%);
  filter: blur(120px); opacity:.22; z-index:0; pointer-events:none; transform: translateY(-20px); animation: heroFloat 16s ease-in-out infinite;
}


@keyframes heroFloat{ 50%{ transform: translateY(0) } }


.mnb-case-hero .media{ position:relative; aspect-ratio:16/7; background:#f0f5fb; isolation:isolate; }


.mnb-case-hero img{ width:100%; height:100%; object-fit:cover; filter: saturate(.95) blur(10px); opacity:.9; transform: scale(1.02); transition: filter .6s var(--mnb-ease), opacity .6s var(--mnb-ease), transform .6s var(--mnb-ease); }


.mnb-case-hero img.is-loaded{ filter:none; opacity:1; transform:none; }


.mnb-case-hero .tag{
  position:absolute; left:12px; bottom:12px; display:inline-flex; align-items:center; gap:.45rem;
  padding:.46rem .66rem; border-radius:10px; font-weight:900; color:#fff;
  background: linear-gradient(135deg, var(--mnb-navy), color-mix(in srgb, var(--mnb-aqua) 40%, var(--mnb-navy)));
  border:1px solid rgba(255,255,255,.22); box-shadow: var(--mnb-shadow);
}


.mnb-case-hero .titlebar{ display:grid; grid-template-columns: 1fr auto; gap: var(--mnb-s-3); align-items:end; padding: var(--mnb-s-4) var(--mnb-s-4) var(--mnb-s-5); }


.mnb-cta{
  display:inline-flex; align-items:center; gap:.55rem; font-weight:900; color:#fff; text-decoration:none;
  background: linear-gradient(135deg, var(--mnb-navy), color-mix(in srgb, var(--mnb-aqua) 40%, var(--mnb-navy)));
  border:1px solid rgba(255,255,255,.25); padding:.72rem 1rem; border-radius:12px; box-shadow: var(--mnb-shadow);
}


.mnb-cta:hover{ filter: brightness(1.06); transform: translateY(-1px); }



/* ============== Main grid modes ============== */
.mnb-case-main{ margin: var(--mnb-s-4) auto var(--mnb-s-7); width: var(--mnb-container); }


.mnb-case[data-layout="stacked"] .mnb-case-main { display:block; }


.mnb-case[data-layout="centered"] .mnb-case-main{
  display:grid; gap: var(--mnb-s-4);
  grid-template-columns: minmax(0,1fr) min(720px, 100%) minmax(0,1fr);
}


.mnb-case[data-layout="centered"] .mnb-case-aside{ grid-column:1; }


.mnb-case[data-layout="centered"] .mnb-case-article{ grid-column:2; }


.mnb-case[data-layout="mobile"] .mnb-case-main{ display:grid; grid-template-columns:1fr; gap: var(--mnb-s-4); }


.mnb-case[data-layout="mobile"] .mnb-case-aside{ display:none; }


@media (max-width:760px){ .mnb-case[data-layout="mobile"] .mnb-case-aside{ display:block; position:sticky; top: calc(var(--mnb-nav-h,72px) + 10px); z-index: 3; } }



/* ============== TOC (pills + scroll spy) ============== */
.mnb-case-aside{
  position: sticky; top: calc(var(--mnb-nav-h,72px) + 16px);
  align-self: start; background:var(--mnb-surface);
  border:1px solid color-mix(in srgb, var(--mnb-line) 90%, transparent);
  border-radius:14px; box-shadow: var(--mnb-shadow); padding: 10px 10px 12px;
}


.mnb-case-aside h4{ margin: 6px 8px 8px; font-size:.92rem; color:var(--mnb-muted); }


.mnb-case-toc{ display:flex; flex-direction:column; gap:8px; }


.mnb-case-toc a{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.56rem .9rem; border-radius:999px; font-weight:800; color:var(--mnb-navy);
  text-decoration:none; border:1px solid var(--mnb-line); background:#fff;
}


.mnb-case-toc a.active{
  background: linear-gradient(135deg, var(--mnb-aqua), var(--mnb-green));
  color:#fff; border-color: transparent;
}



/* ============== Article card + sections ============== */
.mnb-case-article{
  border-radius: var(--mnb-radius-lg);
  border:1px solid color-mix(in srgb, var(--mnb-line) 90%, transparent);
  background: var(--mnb-surface);
  box-shadow: var(--mnb-shadow);
  overflow:hidden;
}


.section{ padding: var(--mnb-s-4) var(--mnb-s-4); opacity:0; transform: translateY(14px); }


.section + .section{ border-top:1px solid color-mix(in srgb, var(--mnb-line) 80%, transparent); }


.section.in{ animation: fadeUp .6s var(--mnb-ease) forwards; }


@keyframes fadeUp{ to{ opacity:1; transform:none; } }



.mnb-eyebrow{ display:inline-block; font-weight:900; font-size:.75rem; letter-spacing:.06em; text-transform:uppercase; color:color-mix(in srgb, var(--mnb-navy) 80%, black); margin-bottom:6px; }


.mnb-case-lead{ font-size: clamp(1.02rem, 1.2vw, 1.15rem); color: var(--mnb-muted); max-width: 72ch; }



/* ============== Badges (metrics & stack) ============== */
.mnb-badges{ display:flex; gap:8px; flex-wrap:wrap; margin-top:10px; }


.mnb-badge{ display:inline-flex; gap:.45rem; align-items:center; padding:.42rem .6rem; border-radius:999px; background:#fff; border:1px solid var(--mnb-line); font-weight:800; color: var(--mnb-navy); }



/* ============== Gallery (hover lift) ============== */
.mnb-case-gallery{ display:grid; gap: var(--mnb-s-3); grid-template-columns: repeat(12, 1fr); }


.mnb-case-gallery .img{
  grid-column: span 6; border-radius:12px; overflow:hidden; border:1px solid var(--mnb-line);
  background:#f6f9ff; box-shadow: var(--mnb-shadow);
  transition: transform .28s var(--mnb-ease), box-shadow .28s var(--mnb-ease);
  cursor: zoom-in;
}


@media (max-width:720px){ .mnb-case-gallery .img{ grid-column: span 12; } }


.mnb-case-gallery .img:hover{ transform: translateY(-6px) scale(1.01); box-shadow: var(--mnb-shadow2); }


.mnb-case-gallery img{ width:100%; height:100%; object-fit:cover; display:block; }



/* Lightbox */
.mnb-lightbox{ position:fixed; inset:0; background: rgba(10,16,26,.8); display:none; align-items:center; justify-content:center; z-index:1000; }


.mnb-lightbox.open{ display:flex; }


.mnb-lightbox img{ max-width:min(92vw, 1200px); max-height: 88vh; border-radius: 12px; border:1px solid rgba(255,255,255,.15); box-shadow:0 30px 80px rgba(0,0,0,.45); }


.mnb-lightbox .close{ position:fixed; top:14px; right:14px; background:#fff; border:1px solid var(--mnb-line); border-radius:999px; padding:.5rem .8rem; font-weight:900; cursor:pointer; }



/* ============== Prev/Next (mini preview vibe) ============== */
.mnb-case-nav{ display:flex; gap: var(--mnb-s-3); margin-top: var(--mnb-s-3); }


.mnb-case-nav a{
  flex:1; display:flex; align-items:center; gap:.6rem; padding:.8rem 1rem; border-radius:12px;
  border:1px solid var(--mnb-line); background:#fff; font-weight:900; color:var(--mnb-navy); box-shadow:var(--mnb-shadow); text-decoration:none;
  transition: transform .2s var(--mnb-ease), box-shadow .2s var(--mnb-ease);
}


.mnb-case-nav a:hover{ transform: translateY(-2px); box-shadow: var(--mnb-shadow2); }



/* ============== Related ============== */
.mnb-related{ width: var(--mnb-container); margin: var(--mnb-s-6) auto var(--mnb-s-7); }


.mnb-related-grid{ display:grid; gap: var(--mnb-s-4); grid-template-columns: repeat(12, 1fr); }


.mnb-related-card{
  grid-column: span 4; border-radius:14px; overflow:hidden; text-decoration:none; color:inherit;
  border:1px solid var(--mnb-line); background:#fff; box-shadow:var(--mnb-shadow);
  transition: transform .2s var(--mnb-ease), box-shadow .2s var(--mnb-ease);
}


.mnb-related-card:hover{ transform: translateY(-4px); box-shadow: var(--mnb-shadow2); }


@media (max-width:1024px){ .mnb-related-card{ grid-column: span 6; } }


@media (max-width:640px){  .mnb-related-card{ grid-column: span 12; } }


.mnb-related-card .cover{ aspect-ratio:16/10; background:#eef4fb; }


.mnb-related-card img{ width:100%; height:100%; object-fit:cover; display:block; }


.mnb-related-card .body{ padding:12px 14px; }



/* Focus ring */
:where(.mnb-case a, .mnb-case button):focus-visible{
  outline: 3px solid color-mix(in srgb, var(--mnb-aqua) 60%, white);
  outline-offset: 2px; border-radius: 10px;
}

/* ===== Tokens / containment ===== */
:root{
  --container: min(1180px, 92vw);
  --nav-h: 72px;
  --s2:12px; --s3:16px; --s4:20px; --s5:28px; --s6:40px; --s7:56px;
  --r:14px; --rl:20px;

  --ink:#0b1422; --muted:#546482; --navy:#27456d; --aqua:#09c7ff;
  --bg:#f5f7fb; --surface:#ffffffea; --line:#e6eef6;
  --shadow: 0 12px 30px rgba(15,25,40,.08), 0 2px 6px rgba(15,25,40,.05);
  --shadow-lg: 0 30px 80px rgba(12, 16, 28, .18);
  --ease: cubic-bezier(.22,.61,.36,1);

  /* Icon sizes */
  --ico-xxs: 12px; --ico-xs: 14px; --ico-sm: 16px;

  /* Gradient tokens */
  --g1: radial-gradient(1200px 600px at 10% -10%, rgba(98, 160, 255, .20), transparent 60%);
  --g2: radial-gradient(900px 520px at 90% 10%, rgba(166, 92, 246, .18), transparent 60%);
  --g3: radial-gradient(800px 560px at 50% 120%, rgba(9, 199, 255, .14), transparent 60%);

  /* Glass + border */
  --glass: blur(10px) saturate(1.05);
  --gbg: linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.58));
  --gbr: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,0)) border-box,
         linear-gradient(180deg, rgba(53, 102, 255, .28), rgba(9,199,255,.26)) padding-box;

  /* Focus */
  --ring: 3px solid color-mix(in srgb, var(--aqua) 60%, white);
}



html,body{max-width:100%;overflow-x:hidden;background:var(--bg);color:var(--ink);}


body::before{
  content:""; position:fixed; inset:-20vh 0 0 0; z-index:-1;
  background: var(--g1), var(--g2), var(--g3);
  opacity:.9; pointer-events:none;
}


.mnb-container{width:var(--container);margin-inline:auto;padding-inline: clamp(12px,3vw,24px);}



/* ===== Icon normalization ===== */
.mnb-careers svg{ width:var(--ico-sm); height:var(--ico-sm); flex:0 0 auto; vertical-align:-2px; }


.mnb-careers use{ vector-effect: non-scaling-stroke; }


.btn svg{ width:var(--ico-xs); height:var(--ico-xs); transform: translateY(1px); }


.tag svg{ width:var(--ico-xxs); height:var(--ico-xxs); transform: translateY(1px); }



/* ===== Jobs grid (only section) ===== */
.jobs{ width: var(--container); margin: calc(var(--nav-h) + var(--s4)) auto var(--s7); }


.job-grid{
  display:grid; gap: clamp(16px, 2.2vw, 22px);
  grid-template-columns: repeat(12, 1fr);
}



/* Card — glass, gradient border, soft highlight */
.job-card{
  grid-column: span 12;
  position:relative;
  background: var(--gbg);
  border: 1px solid transparent; border-radius: var(--r);
  box-shadow: var(--shadow);
  padding: clamp(18px, 2.6vw, 24px);
  display:grid; gap: var(--s3);
  transition: transform .22s var(--ease), box-shadow .22s var(--ease), opacity .45s var(--ease);
  opacity:0; transform: translateY(10px);
  backdrop-filter: var(--glass); -webkit-backdrop-filter: var(--glass);
  background-clip: padding-box, border-box;
  border-image: var(--gbr) 1;
  overflow:hidden;
}


.job-card::after{
  content:""; position:absolute; inset:0 0 auto 0; height:40%;
  background: linear-gradient(180deg, rgba(255,255,255,.18), transparent 60%);
  pointer-events:none;
}


.job-card.in{ opacity:1; transform:none; }


.job-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-lg); }



@media (min-width:860px){ .job-card{ grid-column: span 6; } }



.job-head{ display:flex; justify-content:space-between; gap:12px; align-items:flex-start; }


.job-head h2{
  margin:.1rem 0 .25rem;
  font-size: clamp(1.05rem, 1.2vw + .8rem, 1.42rem);
  letter-spacing:-.01em;
}


.job-meta{ display:flex; gap:8px; flex-wrap:wrap; color: var(--muted); font-weight:800; font-size:.94rem; }


.salary{ color: color-mix(in srgb, var(--navy) 85%, black); font-weight:900; }



/* Department chip */
.chip{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.34rem .64rem; border-radius:999px;
  border:1px solid var(--line); background: color-mix(in srgb, var(--surface) 80%, transparent);
  font-weight:800; font-size:.88rem; color: var(--navy);
}



/* Tags with auto hues */
.tag{
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.36rem .6rem; border-radius:999px;
  background:linear-gradient(180deg, #fff, #f8fbff);
  border:1px solid var(--line);
  font-weight:800; color: var(--navy); font-size:.9rem;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease);
}


@media (prefers-color-scheme: dark){ .tag{ background: linear-gradient(180deg, #11192b, #0e1728); } }


.tag:hover{ transform: translateY(-1px); box-shadow: 0 6px 14px rgba(0,0,0,.06); }


.tag[data-i]{ /* hue shift using index via style or data-i */
  --h: calc((var(--i, 0) * 47) % 360);
  color: hsl(var(--h) 70% 36%);
  border-color: hsl(var(--h) 70% 70% / .35);
}


.tag .dot{ width:.55em; height:.55em; border-radius:999px; background: currentColor; opacity:.85; }



/* Buttons */
.actions{ display:flex; gap:8px; flex-wrap:wrap; }


.btn{
  appearance:none; border:none; cursor:pointer; font-weight:900;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.66rem 1rem; border-radius:12px; text-decoration:none;
  position:relative; isolation:isolate;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
}


.btn:focus-visible{ outline: var(--ring); outline-offset:2px; }


.btn:active{ transform: translateY(1px); }


.btn-primary{
  color:#fff;
  background: linear-gradient(135deg, color-mix(in srgb, var(--navy) 88%, black), color-mix(in srgb, var(--aqua) 42%, var(--navy)));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 10px 24px rgba(50,120,255,.25);
}


.btn-primary:hover{ box-shadow: inset 0 0 0 1px rgba(255,255,255,.22), 0 14px 28px rgba(50,120,255,.32); }


.btn-primary svg{ transition: transform .18s var(--ease); }


.btn-primary:hover svg{ transform: translate(2px, 1px); }


.btn-ghost{
  color:var(--navy);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  border:1px solid var(--line);
}


@media (prefers-color-scheme: dark){
  .btn-ghost{ background: linear-gradient(180deg, rgba(18,26,44,.9), rgba(16,24,40,.8)); }
}



/* ===== Modal ===== */
.modal{
  position:fixed; inset:0; background: rgba(10,16,26,.55);
  display:none; align-items:flex-end; justify-content:center; z-index:1000;
  backdrop-filter: blur(2px);
}


.modal.open{ display:flex; }


.sheet{
  width: min(920px, 96vw); max-height: 86vh; overflow:auto;
  background: var(--gbg);
  border:1px solid transparent; border-radius: 18px 18px 0 0;
  box-shadow: var(--shadow-lg);
  backdrop-filter: var(--glass); -webkit-backdrop-filter: var(--glass);
  border-image: var(--gbr) 1;
}


.sheet-head{
  position:sticky; top:0; z-index:1;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding: 14px 16px; border-bottom:1px solid var(--line);
  background: inherit;
}


.sheet-body{ padding: 16px; display:grid; gap:12px; }


.modal-close{
  appearance:none; border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.85));
  border-radius:10px; padding:.55rem .9rem; font-weight:900; cursor:pointer;
}


@media (prefers-color-scheme: dark){
  .modal-close{ background: linear-gradient(180deg, rgba(18,26,44,.95), rgba(18,26,44,.82)); }
}



/* ===== Drawer (Apply) ===== */
.drawer{
  position: fixed; right: 0; top: 0;
  width: 440px; max-width: calc(100vw - 24px); height: 100vh;
  background: var(--gbg);
  border-left:1px solid transparent; border-image: var(--gbr) 1;
  box-shadow: -30px 0 80px rgba(0,0,0,.25);
  transform: translateX(100%); transition: transform .32s var(--ease); z-index: 1001;
  display:flex; flex-direction:column; backdrop-filter: var(--glass); -webkit-backdrop-filter: var(--glass);
}


.drawer.open{ transform: translateX(0); }


.drawer-head{
  position:sticky; top:0; z-index:1;
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:14px 16px; border-bottom:1px solid var(--line); background:inherit;
}


.drawer-body{ padding: 16px; overflow:auto; }


.row{ display:grid; gap:8px; margin-bottom:12px; }


.row input, .row textarea{
  width:100%; padding:.78rem .9rem; border-radius:12px;
  border:1px solid var(--line); background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
  color:var(--ink); box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
}


@media (prefers-color-scheme: dark){
  .row input, .row textarea{ background: linear-gradient(180deg, rgba(18,26,44,.96), rgba(18,26,44,.88)); }
}


.row input:focus-visible, .row textarea:focus-visible{ outline: var(--ring); }


.drawer-foot{ margin-top:auto; padding: 12px 16px; border-top:1px solid var(--line); display:flex; gap:8px; justify-content:flex-end; background: inherit; }



/* ===== Empty state ===== */
.empty{
  grid-column: span 12; text-align:center; color: var(--muted); padding: 18px;
  border:1px dashed var(--line); border-radius: var(--r);
  background: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,.55));
}



/* ===== Fine details ===== */
.job-lead{ margin:0; color:var(--muted); }


.card-row{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }



/* Scrollbar polish */
.sheet::-webkit-scrollbar, .drawer-body::-webkit-scrollbar{ width:10px; }


.sheet::-webkit-scrollbar-thumb, .drawer-body::-webkit-scrollbar-thumb{
  background: color-mix(in srgb, var(--navy) 28%, transparent); border-radius:999px;
  border:2px solid transparent; background-clip: content-box;
}



/* Motion-reduction */
@media (prefers-reduced-motion: reduce){
  .job-card, .btn, .tag, .btn-primary svg{ transition: none !important; }
  .job-card{ transform:none !important; }
}

/* ===== Flush layout ===== */
html, body { margin:0; padding:0; }



/* ===== Tokens (compact sizing) ===== */
:root{
  --container: min(1180px, 92vw);
  --nav-h: 72px;

  /* spacing scale (slightly tighter) */
  --s2:10px; --s3:14px; --s4:18px; --s5:24px; --s6:36px; --s7:48px;

  /* radii */
  --r:12px; --rl:18px;

  /* button sizing — key change */
  --btn-py: .48rem;
  --btn-px: .78rem;
  --btn-radius: 10px;
  --btn-font: 0.95rem; /* slightly smaller */

  /* input sizing */
  --field-py: .64rem;
  --field-px: .8rem;
  --field-radius: 10px;

  /* typographic tweaks */
  --h1: clamp(1.4rem, 1.1vw + 1.2rem, 2.0rem);
  --h4: 1rem;

  /* colors */
  --ink:#0b1422; --muted:#5b6a86; --navy:#27456d; --aqua:#09c7ff;
  --bg:#f6f8fb; --surface:#ffffffea; --line:#e6eef6;
  --shadow: 0 10px 26px rgba(15,25,40,.08), 0 1px 4px rgba(15,25,40,.04);
  --shadow-lg: 0 22px 70px rgba(12,16,28,.16);
  --ease: cubic-bezier(.22,.61,.36,1);

  /* glass gradients */
  --gbg: linear-gradient(180deg, rgba(255,255,255,.74), rgba(255,255,255,.58));
  --gbr: linear-gradient(180deg, rgba(255,255,255,.66), rgba(255,255,255,0)) border-box,
         linear-gradient(180deg, rgba(53,102,255,.28), rgba(9,199,255,.22)) padding-box;

  --ring: 3px solid color-mix(in srgb, var(--aqua) 55%, white);
  --link: color-mix(in srgb, var(--navy) 60%, var(--aqua));
}


@media (prefers-color-scheme: dark){
  :root{
    --bg:#0e1522; --surface:#0f1626d9; --line:#24344f; --ink:#eef4ff; --muted:#aab9d7;
    --navy:#6aa3ff; --aqua:#33d6ff; --shadow:none; --shadow-lg: 0 26px 80px rgba(0,0,0,.44);
    --gbg: linear-gradient(180deg, rgba(21,28,46,.76), rgba(18,24,40,.62));
    --gbr: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0)) border-box,
           linear-gradient(180deg, rgba(102,153,255,.32), rgba(51,214,255,.24)) padding-box;
  }
}



/* ===== Page canvas ===== */
.mnb-contact-page{ background:var(--bg); color:var(--ink); }


.mnb-contact-page::before{
  content:""; position:fixed; inset:-20vh 0 0 0; z-index:-1;
  background:
    radial-gradient(1200px 560px at 6% -10%, rgba(98,160,255,.18), transparent 60%),
    radial-gradient(900px 500px at 94% 10%, rgba(166,92,246,.14), transparent 60%),
    radial-gradient(800px 520px at 50% 120%, rgba(9,199,255,.10), transparent 60%);
  pointer-events:none;
}


.mnb-contact-page .mnb-container{ width:var(--container); margin-inline:auto; padding-inline: clamp(12px,3vw,24px); }


.mnb-contact-page main{ margin:0; padding:0; }



/* ===== Layout ===== */
.mnb-contact-page .layout{
  width: var(--container);
  margin: calc(var(--nav-h) + var(--s4)) auto var(--s6);
  display:grid; gap: clamp(14px,2vw,18px);
  grid-template-columns: 1fr;
}


@media (min-width:1100px){
  .mnb-contact-page .layout{
    grid-template-columns: minmax(0, 1fr) 340px;
    align-items:start;
  }
}



/* ===== Header ===== */
.mnb-contact-page .hero{
  display:grid; gap:8px; padding:8px 0;
  border-bottom: 1px dashed color-mix(in srgb, var(--line) 80%, transparent);
}


.mnb-contact-page h1{ margin:0; letter-spacing:-.02em; font-size: var(--h1); }


.mnb-contact-page .sub{ color: var(--muted); margin:0; max-width: 78ch; }


.mnb-contact-page .page-content a{ color: var(--link); text-decoration: none; }


.mnb-contact-page .page-content a:hover{ text-decoration: underline; }



/* ===== Cards ===== */
.mnb-contact-page .card,
.mnb-contact-page .info-card{
  border:1px solid transparent;
  background: var(--gbg);
  background-clip: padding-box, border-box;
  border-image: var(--gbr) 1;
  border-radius: var(--r); box-shadow: var(--shadow); overflow:hidden;
}


.mnb-contact-page .card-head,
.mnb-contact-page .info-head{
  padding:12px 14px; border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}


.mnb-contact-page .card-body{ padding:14px; display:grid; gap:10px; }


.mnb-contact-page .info-body{ padding:12px; display:grid; gap:10px; }



/* ===== Form fields (compact) ===== */
.mnb-contact-page .row{ display:grid; gap:6px; }


.mnb-contact-page .row.inline{ grid-template-columns: 1fr; gap:10px; }


@media (min-width:760px){
  .mnb-contact-page .row.inline{ grid-template-columns: 1fr 1fr; }
}


.mnb-contact-page label{ font-weight:800; font-size:.96rem; }


.mnb-contact-page input, .mnb-contact-page select, .mnb-contact-page textarea{
  width:100%; padding: var(--field-py) var(--field-px); border-radius: var(--field-radius);
  border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
  color:var(--ink); box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
  font-size: .98rem;
}


@media (prefers-color-scheme: dark){
  .mnb-contact-page input, .mnb-contact-page select, .mnb-contact-page textarea{
    background: linear-gradient(180deg, rgba(18,26,44,.96), rgba(18,26,44,.88));
  }
}


.mnb-contact-page input:focus-visible, .mnb-contact-page select:focus-visible, .mnb-contact-page textarea:focus-visible{ outline: var(--ring); }


.mnb-contact-page .help{ color: var(--muted); font-size:.9rem; }



/* ===== Actions (smaller buttons) ===== */
.mnb-contact-page .actions{
  display:flex; gap:8px; justify-content:flex-end;
  padding: 10px 14px; border-top:1px solid var(--line);
}


.mnb-contact-page .btn{
  appearance:none; border:none; cursor:pointer; font-weight:800;
  display:inline-flex; align-items:center; gap:.45rem;
  padding: var(--btn-py) var(--btn-px);
  border-radius: var(--btn-radius); text-decoration:none;
  font-size: var(--btn-font); line-height:1;
}


.mnb-contact-page .btn svg{ width:14px; height:14px; transform: translateY(1px); }


.mnb-contact-page .btn:focus-visible{ outline: var(--ring); outline-offset:2px; }


.mnb-contact-page .btn-primary{
  color:#fff; background: linear-gradient(135deg, color-mix(in srgb, var(--navy) 88%, black), color-mix(in srgb, var(--aqua) 42%, var(--navy)));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.16), 0 8px 20px rgba(50,120,255,.20);
}


.mnb-contact-page .btn-ghost{
  color:var(--navy); background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  border:1px solid var(--line);
}


@media (prefers-color-scheme: dark){
  .mnb-contact-page .btn-ghost{ background: linear-gradient(180deg, rgba(18,26,44,.9), rgba(16,24,40,.8)); color: var(--ink); }
}



/* ===== Sidebar ===== */
.mnb-contact-page .sidebar{ position:relative; }


@media (min-width:1100px){ .mnb-contact-page .sidebar-inner{ position: sticky; top: calc(var(--nav-h) + 16px); } }


.mnb-contact-page .quick{
  display:grid; gap:6px;
}


.mnb-contact-page .quick a{
  display:flex; align-items:center; gap:8px; text-decoration:none; font-weight:800;
  border:1px solid var(--line); border-radius: var(--btn-radius);
  padding: calc(var(--btn-py) - 2px) calc(var(--btn-px) - 2px);
  background:linear-gradient(180deg, #fff, #f7fbff); color: var(--navy);
  font-size: .95rem;
}


.mnb-contact-page .quick a:hover{ box-shadow: 0 8px 18px rgba(50,120,255,.08); transform: translateY(-1px); }


@media (prefers-color-scheme: dark){
  .mnb-contact-page .quick a{ background: linear-gradient(180deg, #111a2d, #0f1728); color:var(--ink); }
}


.mnb-contact-page .quick svg{ width:14px; height:14px; opacity:.85; }


.mnb-contact-page .muted{ color:var(--muted); font-size:.95rem; }



.mnb-contact-page .office{
  border-top:1px dashed var(--line); padding-top:8px; display:grid; gap:6px;
}


.mnb-contact-page .office h4{ margin:0; font-size:var(--h4); letter-spacing:-.01em; }


.mnb-contact-page .map{ margin-top:6px; border-radius:10px; overflow:hidden; border:1px solid var(--line); }


.mnb-contact-page .map img{ width:100%; height:auto; display:block; }



/* Reveal */
.mnb-contact-page .reveal{ opacity:0; transform: translateY(10px); transition: transform .22s var(--ease), opacity .45s var(--ease); }


.mnb-contact-page .reveal.in{ opacity:1; transform:none; }



/* Motion reduction */
@media (prefers-reduced-motion: reduce){
  .mnb-contact-page .reveal{ transition:none !important; transform:none !important; }
}



/* ===== Tokens ===== */
:root{
  --container: min(1180px, 92vw);
  --nav-h: 72px;
  --s2:12px; --s3:16px; --s4:20px; --s5:28px; --s6:40px; --s7:56px;
  --r:16px; --rl:22px;

  --ink:#0b1422; --muted:#5b6a86; --navy:#27456d; --aqua:#09c7ff;
  --bg:#f6f8fb; --surface:#ffffffea; --line:#e6eef6;
  --shadow: 0 14px 34px rgba(15,25,40,.08), 0 2px 6px rgba(15,25,40,.05);
  --shadow-lg: 0 28px 100px rgba(12,16,28,.18);
  --ease: cubic-bezier(.22,.61,.36,1);

  --g1: radial-gradient(1200px 600px at 6% -10%, rgba(98,160,255,.18), transparent 60%);
  --g2: radial-gradient(900px 520px at 94% 10%, rgba(166,92,246,.16), transparent 60%);
  --g3: radial-gradient(800px 560px at 50% 120%, rgba(9,199,255,.12), transparent 60%);

  --glass: blur(10px) saturate(1.05);
  --gbg: linear-gradient(180deg, rgba(255,255,255,.76), rgba(255,255,255,.60));
  --gbr: linear-gradient(180deg, rgba(255,255,255,.7), rgba(255,255,255,0)) border-box,
         linear-gradient(180deg, rgba(53,102,255,.30), rgba(9,199,255,.26)) padding-box;

  --ring: 3px solid color-mix(in srgb, var(--aqua) 55%, white);
  --link: color-mix(in srgb, var(--navy) 60%, var(--aqua));
}


@media (prefers-color-scheme: dark){
  :root{
    --bg:#0e1522; --surface:#0f1626d9; --line:#24344f; --ink:#eef4ff; --muted:#aab9d7;
    --navy:#6aa3ff; --aqua:#33d6ff; --shadow:none; --shadow-lg: 0 30px 90px rgba(0,0,0,.45);
    --gbg: linear-gradient(180deg, rgba(21,28,46,.78), rgba(18,24,40,.66));
    --gbr: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0)) border-box,
           linear-gradient(180deg, rgba(102,153,255,.35), rgba(51,214,255,.28)) padding-box;
  }
}



/* ===== Page canvas ===== */
.mnb-faqs-page{ background:var(--bg); color:var(--ink); }


.mnb-faqs-page::before{
  content:""; position:fixed; inset:-20vh 0 0 0; z-index:-1;
  background: var(--g1), var(--g2), var(--g3); pointer-events:none;
}


.mnb-faqs-page .mnb-container{ width:var(--container); margin-inline:auto; padding-inline: clamp(12px,3vw,24px); }


.mnb-faqs-page main{ margin:0; padding:0; }



/* ===== Layout: Left content + Right sidebar ===== */
.mnb-faqs-page .layout{
  width: var(--container);
  margin: calc(var(--nav-h) + var(--s4)) auto var(--s7);
  display:grid; gap: clamp(16px,2vw,22px);
  grid-template-columns: 1fr;
}


@media (min-width:1100px){
  .mnb-faqs-page .layout{
    grid-template-columns: minmax(0, 1fr) 340px;
    align-items:start;
  }
}



/* ===== Header strip ===== */
.mnb-faqs-page .hero{
  display:grid; gap:10px; padding:12px 0;
  border-bottom: 1px dashed color-mix(in srgb, var(--line) 80%, transparent);
}


.mnb-faqs-page h1{ margin:0; letter-spacing:-.02em; font-size: clamp(1.6rem, 1.4vw + 1.4rem, 2.3rem); }


.mnb-faqs-page .sub{ color: var(--muted); margin:0; max-width: 78ch; }



/* Scope link styling to FAQs content only (prevents bleed to included files) */
.mnb-faqs-page .faq-content a{ color: var(--link); text-decoration: none; }


.mnb-faqs-page .faq-content a:hover{ text-decoration: underline; }



/* ===== Tools: two rows (search row, then chips row) ===== */
.mnb-faqs-page .tools{
  display:grid; grid-template-columns: 1fr; gap: 10px; margin-top: 6px;
}


.mnb-faqs-page .tools-row{
  display:flex; align-items:center; gap:10px;
}


.mnb-faqs-page .chips-row{
  display:flex; align-items:center; justify-content:flex-start;
}



/* Search field and inline action buttons */
.mnb-faqs-page .search{
  position:relative; flex: 1 1 auto; min-width:260px; max-width:720px;
}


.mnb-faqs-page .search input{
  width:100%; padding:.86rem 5.8rem .86rem .95rem; border-radius:12px; border:1px solid var(--line);
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9));
  color:var(--ink); box-shadow: inset 0 1px 0 rgba(255,255,255,.35);
}


@media (prefers-color-scheme: dark){
  .mnb-faqs-page .search input{ background: linear-gradient(180deg, rgba(18,26,44,.96), rgba(18,26,44,.88)); color: var(--ink); }
}


.mnb-faqs-page .search input:focus-visible{ outline: var(--ring); }


.mnb-faqs-page .search .icons{
  position:absolute; right:.6rem; top:50%; transform: translateY(-50%);
  display:inline-flex; gap:6px;
}


.mnb-faqs-page .search .icons .btn{
  padding:.42rem .6rem; border-radius:10px;
}



/* Chips */
.mnb-faqs-page .chips{ display:flex; flex-wrap:wrap; gap:8px; }


.mnb-faqs-page .chip{
  appearance:none; border:1px solid var(--line); background:linear-gradient(180deg, #fff, #f7fbff);
  color:var(--navy); border-radius:999px; padding:.42rem .7rem; font-weight:800; cursor:pointer;
}


.mnb-faqs-page .chip[aria-pressed="true"]{
  color:#fff; background: linear-gradient(135deg, color-mix(in srgb, var(--navy) 88%, black), color-mix(in srgb, var(--aqua) 42%, var(--navy)));
  border-color: transparent; box-shadow: 0 8px 18px rgba(50,120,255,.25);
}


.mnb-faqs-page .chip:focus-visible{ outline: var(--ring); outline-offset:2px; }


@media (prefers-color-scheme: dark){
  .mnb-faqs-page .chip{ background: linear-gradient(180deg, #111a2d, #0f1728); color:var(--ink); }
}



/* Buttons */
.mnb-faqs-page .btn{
  appearance:none; border:none; cursor:pointer; font-weight:900;
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.62rem .95rem; border-radius:12px; text-decoration:none;
}


.mnb-faqs-page .btn:focus-visible{ outline: var(--ring); outline-offset:2px; }


.mnb-faqs-page .btn-primary{
  color:#fff; background: linear-gradient(135deg, color-mix(in srgb, var(--navy) 88%, black), color-mix(in srgb, var(--aqua) 42%, var(--navy)));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 10px 24px rgba(50,120,255,.25);
}


.mnb-faqs-page .btn-ghost{
  color:var(--navy); background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.78));
  border:1px solid var(--line);
}


@media (prefers-color-scheme: dark){
  .mnb-faqs-page .btn-ghost{ background: linear-gradient(180deg, rgba(18,26,44,.9), rgba(16,24,40,.8)); color: var(--ink); }
}



/* Status under tools */
.mnb-faqs-page .statusbar{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap; color: var(--muted); font-size:.95rem;
}


.mnb-faqs-page .count{
  font-weight:900; color: var(--navy); padding:.38rem .6rem; border-radius:10px;
  background: linear-gradient(180deg, #fff, #f7fbff); border:1px solid var(--line);
}


@media (prefers-color-scheme: dark){
  .mnb-faqs-page .count{ background: linear-gradient(180deg, #111a2d, #0f1728); color: var(--ink); }
}



/* ===== FAQ grid: two card columns ===== */
.mnb-faqs-page .faq-grid{
  display:grid; gap: clamp(14px,2vw,18px);
  grid-template-columns: 1fr;
}


@media (min-width:760px){ .mnb-faqs-page .faq-grid{ grid-template-columns: 1fr 1fr; } }



.mnb-faqs-page .faq{
  border:1px solid transparent; background: var(--gbg); background-clip: padding-box, border-box; border-image: var(--gbr) 1;
  border-radius: var(--r); box-shadow: var(--shadow); overflow:hidden; display:flex; flex-direction:column;
}


.mnb-faqs-page .faq-item{ border-top:1px solid var(--line); }


.mnb-faqs-page .faq-item:first-child{ border-top:0; }



.mnb-faqs-page .faq-q{
  all:unset; display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:10px;
  width:100%; padding:14px 16px; cursor:pointer;
}


.mnb-faqs-page .faq-q:hover{ background: color-mix(in srgb, var(--surface) 92%, transparent); }


.mnb-faqs-page .faq-q:focus-visible{ outline: var(--ring); outline-offset:-4px; }


.mnb-faqs-page .qtag{
  font-size:.78rem; line-height:1; color: var(--navy); font-weight:900;
  background:linear-gradient(180deg, #fff, #f7fbff); border:1px solid var(--line);
  padding:.32rem .5rem; border-radius:999px;
}


@media (prefers-color-scheme: dark){
  .mnb-faqs-page .qtag{ background: linear-gradient(180deg, #111a2d, #0f1728); color:var(--ink); }
}


.mnb-faqs-page .qtext{ font-weight:900; letter-spacing:-.01em; }



.mnb-faqs-page .chev{ width:16px; height:16px; transform:rotate(0deg); transition: transform .18s var(--ease); opacity:.85; }


.mnb-faqs-page .faq-item[open] .chev{ transform:rotate(180deg); }



.mnb-faqs-page .faq-a{
  overflow:hidden; height:0; padding:0 16px; transition: height .22s var(--ease), padding .22s var(--ease);
}


.mnb-faqs-page .faq-item[open] .faq-a{ padding: 0 16px 14px; }


.mnb-faqs-page .faq-a > div{ padding-top:6px; color:var(--ink); line-height:1.65; }



/* ===== Sidebar (sticky) ===== */
.mnb-faqs-page .sidebar{ position:relative; }


@media (min-width:1100px){ .mnb-faqs-page .sidebar-inner{ position: sticky; top: calc(var(--nav-h) + 18px); } }



.mnb-faqs-page .side-card{
  border:1px solid transparent; background: var(--gbg); background-clip: padding-box, border-box; border-image: var(--gbr) 1;
  border-radius: var(--r); box-shadow: var(--shadow); overflow:hidden; display:grid;
}


.mnb-faqs-page .side-head{
  padding:14px 16px; border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between; gap:10px;
}


.mnb-faqs-page .side-head h3{ margin:0; font-size:1.02rem; letter-spacing:-.01em; }



.mnb-faqs-page .services{ display:grid; gap:8px; padding:12px; }


.mnb-faqs-page .pill{
  display:flex; align-items:center; gap:8px; text-decoration:none;
  border:1px solid var(--line); border-radius:12px; padding:.56rem .7rem;
  background:linear-gradient(180deg, #fff, #f7fbff); color: var(--navy); font-weight:800;
}


.mnb-faqs-page .pill:hover{ box-shadow: 0 8px 18px rgba(50,120,255,.08); transform: translateY(-1px); }


@media (prefers-color-scheme: dark){
  .mnb-faqs-page .pill{ background: linear-gradient(180deg, #111a2d, #0f1728); color: var(--ink); }
}


.mnb-faqs-page .svc-badge{
  margin-left:auto; font-size:.72rem; font-weight:900; color:#fff;
  padding:.22rem .46rem; border-radius:999px;
  background: color-mix(in srgb, var(--navy) 75%, var(--aqua));
}


.mnb-faqs-page .side-foot{
  padding:12px; border-top:1px solid var(--line); display:flex; gap:8px; justify-content:flex-end;
}



/* Empty state */
.mnb-faqs-page .empty{
  border:1px dashed var(--line); border-radius:var(--r);
  padding:16px; text-align:center; color:var(--muted);
}



/* Reveal */
.mnb-faqs-page .reveal{ opacity:0; transform: translateY(12px); transition: transform .22s var(--ease), opacity .45s var(--ease); }


.mnb-faqs-page .reveal.in{ opacity:1; transform:none; }



/* Motion reduction */
@media (prefers-reduced-motion: reduce){
  .mnb-faqs-page .reveal, .mnb-faqs-page .faq-a{ transition:none !important; }
}


/* ===========================================================
   MNB Enhancements — animations, hovers, borders, utilities
   (Safe defaults + prefers-reduced-motion)
   =========================================================== */

/* Motion guard */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
}

/* --- Focus ring (consistent, accessible) --- */
:root{ --mnb-focus: 0 0 0 3px rgba(124, 58, 237, .35); }
:focus-visible{ outline: none; box-shadow: var(--mnb-focus); border-radius: .75rem; }

/* --- Smooth scrolling for anchor navs --- */
html { scroll-behavior: smooth; }

/* --- Reveal on scroll (hook with .reveal-up/.reveal-in) --- */
.reveal-up{ opacity:0; transform: translateY(16px); transition: opacity .6s ease, transform .6s ease; }
.reveal-up.is-in{ opacity:1; transform: translateY(0); }
.reveal-in{ opacity:0; transform: scale(.98); transition: opacity .5s ease, transform .5s ease; }
.reveal-in.is-in{ opacity:1; transform: scale(1); }

/* --- Float / subtle bob for hero shapes --- */
@keyframes mnb-float { 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-8px) } }
.mnb-float { animation: mnb-float 6s ease-in-out infinite; }

/* --- Hover lift + shadow pop for cards/buttons --- */
.mnb-hover-lift{ transition: transform .25s ease, box-shadow .25s ease; will-change: transform; }
.mnb-hover-lift:hover{ transform: translateY(-6px); box-shadow: 0 20px 40px -20px rgba(20,20,50,.25); }
.mnb-tap-scale:active{ transform: scale(.98); }

/* --- Gradient border utility --- */
.mnb-gradient-border{ position: relative; }
.mnb-gradient-border::before{
  content:""; position:absolute; inset:0; border-radius: inherit; padding:1px;
  background: linear-gradient(135deg, #8b5cf6, #06b6d4, #22d3ee);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events:none;
}

/* --- Soft hairline borders for cards/sections --- */
.mnb-hairline{ border: 1px solid rgba(120, 120, 140, .15); }
.mnb-hairline-strong{ border: 1px solid rgba(120, 120, 140, .28); }

/* --- Image hover shine --- */
.mnb-shine{ position: relative; overflow:hidden; }
.mnb-shine::after{
  content:""; position:absolute; inset: -150% -50% auto auto; width:50%; transform: rotate(25deg);
  background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.55) 50%, rgba(255,255,255,0) 100%);
  transition: transform .7s ease;
}
.mnb-shine:hover::after{ transform: translate3d(-150%,0,0) rotate(25deg); }

/* --- Link underline grow (colored links) --- */
a.mnb-link{ position:relative; text-decoration:none; }
a.mnb-link::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px;
  background: currentColor; transition: right .25s ease;
}
a.mnb-link:hover::after{ right:0; }

/* --- Button presets (use with existing .mnb-btn) --- */
.mnb-btn{ display:inline-flex; align-items:center; gap:.5rem; font-weight:600; border-radius: .75rem; padding: var(--btn-py,.7rem) var(--btn-px,1rem); transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease; }
.mnb-btn-primary{ color:#fff; background: linear-gradient(135deg,#7c3aed,#22d3ee); box-shadow: 0 10px 20px -10px rgba(124,58,237,.45); }
.mnb-btn-primary:hover{ filter: brightness(1.04); transform: translateY(-2px); }
.mnb-btn-outline{ color:#0f172a; background: #fff; border:1px solid rgba(15,23,42,.15); }
.mnb-btn-outline:hover{ border-color: rgba(15,23,42,.3); box-shadow: 0 12px 24px -18px rgba(15,23,42,.25); }

/* --- Card surface helpers --- */
.mnb-card{ border-radius: 1rem; background: rgba(255,255,255,.8); backdrop-filter: blur(8px); }
.mnb-card.elev-1{ box-shadow: 0 6px 14px -8px rgba(20,20,50,.25); }
.mnb-card.elev-2{ box-shadow: 0 18px 42px -22px rgba(20,20,50,.3); }
.mnb-card .mnb-card-cta{ opacity:.85; transition: opacity .2s ease, transform .2s ease; }
.mnb-card:hover .mnb-card-cta{ opacity:1; transform: translateX(2px); }

/* --- Nav: sticky shadow on scroll --- */
.mnb-sticky-shadow{ transition: box-shadow .2s ease, background-color .2s ease; }
.mnb-sticky-shadow.is-scrolled{ background: rgba(255,255,255,.8); backdrop-filter: blur(8px); box-shadow: 0 8px 24px -18px rgba(20,20,50,.35); }

/* --- Utility spacing & radius (lightweight) --- */
.r-8{ border-radius: .5rem; } .r-12{ border-radius: .75rem; } .r-16{ border-radius: 1rem; }
.p-16{ padding:1rem; } .p-24{ padding:1.5rem; } .p-32{ padding:2rem; }
.mt-24{ margin-top:1.5rem; } .mb-24{ margin-bottom:1.5rem; } .gap-16{ gap:1rem; }

/* --- Media hover safety --- */
@media (hover: hover){ .hover-show:hover{ opacity:1 !important; } }

