  :root{
    --bg:#ffffff;
    --bg-soft:#eef0f4;
    --bg-soft-2:#e4e7ec;
    --ink:#15181d;          /* near-black */
    --ink-2:#2b2f36;
    --muted:#646c78;        /* grey */
    --line:#e4e7ec;
    --line-strong:#d3d7de;
    --red:#ff3131;          /* brand red (sampled from logo) */
    --red-dark:#d61f1f;
    --black:#15181d;
    /* dashboard (dark) tokens */
    --d-bg:#16191f;
    --d-panel:#1e222b;
    --d-line:rgba(255,255,255,.08);
    --d-ink:#f1f3f6;
    --d-muted:#9aa3b1;
    --ok:#27c08a;
    --radius:16px;
    --maxw:1160px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
    color:var(--ink);
    background:var(--bg);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  a{color:inherit;text-decoration:none}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{
    text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;
    font-weight:800;color:var(--red)
  }
  h1,h2,h3{line-height:1.15;letter-spacing:-.01em;color:var(--ink)}
  .btn{
    display:inline-flex;align-items:center;gap:.5rem;
    padding:.85rem 1.4rem;border-radius:999px;font-weight:700;font-size:.98rem;
    transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
    cursor:pointer;border:0;
  }
  .btn-primary{background:var(--red);color:#fff;box-shadow:0 8px 22px rgba(214,35,43,.30)}
  .btn-primary:hover{transform:translateY(-2px);background:var(--red-dark);box-shadow:0 12px 28px rgba(214,35,43,.40)}
  .btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line-strong)}
  .btn-ghost:hover{border-color:var(--red);color:var(--red)}
  .btn-dark{background:var(--black);color:#fff}
  .btn-dark:hover{transform:translateY(-2px);background:#000}

  /* Header */
  header{
    position:sticky;top:0;z-index:50;
    backdrop-filter:blur(10px);
    background:rgba(255,255,255,.85);
    border-bottom:1px solid var(--line);
  }
  .nav{display:flex;align-items:center;justify-content:space-between;height:72px}
  .logo{display:flex;align-items:center;gap:.6rem;font-weight:900;font-size:1.25rem;letter-spacing:.02em;color:var(--ink)}
  .logo img{height:38px;width:auto;display:block}
  footer .logo img{height:34px}
  .nav-links{display:flex;gap:1.7rem;align-items:center;font-size:.95rem;color:var(--muted);font-weight:600}
  .nav-links a:hover{color:var(--ink)}
  .nav-cta{display:flex;align-items:center;gap:1rem}
  .phone{font-weight:800;color:var(--ink);font-size:1rem;white-space:nowrap}
  @media(max-width:860px){.nav-links{display:none}.phone{display:none}}

  /* Hero */
  .hero{
    position:relative;overflow:hidden;
    background:
      radial-gradient(900px 480px at 88% -10%, rgba(255,49,49,.07), transparent 60%),
      linear-gradient(180deg,#f5f6f8,var(--bg-soft));
    padding:84px 0 76px;
    border-bottom:1px solid var(--line);
  }
  .hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .hero h1{font-size:clamp(2.3rem,5vw,3.55rem);font-weight:900;margin:.6rem 0 1rem}
  .hero h1 span{color:var(--red)}
  .hero p.lead{font-size:1.15rem;color:var(--muted);max-width:560px;margin-bottom:1.8rem}
  .hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.6rem}
  .hero-trust{display:flex;gap:1.4rem;flex-wrap:wrap;color:var(--muted);font-size:.9rem;font-weight:600}
  .hero-trust span{display:flex;align-items:center;gap:.45rem}
  .check{color:var(--red);font-weight:900}
  @media(max-width:860px){.hero-grid{grid-template-columns:1fr}}

  /* ===== Live NOC Dashboard ===== */
  .noc{
    background:var(--d-bg);
    border:1px solid var(--d-line);
    border-radius:18px;
    padding:20px;
    color:var(--d-ink);
    box-shadow:0 30px 60px rgba(20,23,29,.28);
  }
  .noc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
  .noc-title{display:flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:.02em}
  .noc-title .live{
    display:inline-flex;align-items:center;gap:.4rem;font-size:.72rem;font-weight:800;
    text-transform:uppercase;letter-spacing:.1em;color:var(--ok);
    background:rgba(39,192,138,.12);padding:3px 9px;border-radius:999px
  }
  .pulse{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(39,192,138,.6);animation:pulse 1.8s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(39,192,138,.55)}70%{box-shadow:0 0 0 8px rgba(39,192,138,0)}100%{box-shadow:0 0 0 0 rgba(39,192,138,0)}}
  .noc-sub{font-size:.74rem;color:var(--d-muted)}
  .noc-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
  .tile{background:var(--d-panel);border:1px solid var(--d-line);border-radius:12px;padding:14px 16px}
  .tile .lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--d-muted);display:flex;align-items:center;gap:.4rem}
  .tile .val{font-size:1.9rem;font-weight:900;margin-top:6px;font-variant-numeric:tabular-nums;line-height:1}
  .tile .val small{font-size:.8rem;font-weight:700;color:var(--d-muted)}
  .tile .delta{font-size:.72rem;font-weight:700;margin-top:4px}
  .delta.up{color:var(--ok)} .delta.red{color:#ff6b72}
  .dot-red{width:7px;height:7px;border-radius:50%;background:var(--red);display:inline-block}
  .dot-grn{width:7px;height:7px;border-radius:50%;background:var(--ok);display:inline-block}
  .dot-amb{width:7px;height:7px;border-radius:50%;background:#f5b14c;display:inline-block}
  /* feed */
  .noc-feed{margin-top:14px;background:var(--d-panel);border:1px solid var(--d-line);border-radius:12px;padding:10px 14px}
  .feed-head{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--d-muted);margin-bottom:8px;display:flex;justify-content:space-between}
  .feed-list{list-style:none;font-size:.82rem;height:104px;overflow:hidden;position:relative}
  .feed-list li{display:flex;gap:.55rem;padding:5px 0;color:var(--d-ink);align-items:baseline;animation:slideIn .4s ease}
  @keyframes slideIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
  .feed-list li time{color:var(--d-muted);font-variant-numeric:tabular-nums;font-size:.72rem;min-width:52px}
  .feed-list li .ico{margin-top:5px}
  @media(max-width:860px){.noc-tiles{grid-template-columns:repeat(2,1fr)}}

  /* ===== Live Threat Map ===== */
  .threat{background:var(--d-bg);color:var(--d-ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .threat .eyebrow{color:#ff6b72}
  .threat h2{color:#fff}
  .threat .section-head p{color:var(--d-muted)}
  .tm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:0 0 22px}
  .tm-stat{background:var(--d-panel);border:1px solid var(--d-line);border-radius:12px;padding:14px 16px}
  .tm-stat .lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--d-muted);display:flex;align-items:center;gap:.4rem}
  .tm-stat .val{font-size:1.7rem;font-weight:900;margin-top:4px;font-variant-numeric:tabular-nums;line-height:1}
  .tm-stat .val small{font-size:.85rem;color:var(--d-muted);font-weight:700}
  .tm-wrap{position:relative;border:1px solid var(--d-line);border-radius:16px;overflow:hidden;background:radial-gradient(1200px 520px at 50% -10%,#1c2433,#13161c)}
  #threatCanvas{display:block;width:100%;height:clamp(300px,44vw,560px)}
  .tm-legend{position:absolute;top:14px;right:16px;display:flex;gap:16px;font-size:.74rem;color:var(--d-muted)}
  .tm-legend span{display:flex;align-items:center;gap:.4rem}
  .tm-ld{width:8px;height:8px;border-radius:50%;display:inline-block}
  .tm-feed{position:absolute;left:14px;bottom:14px;width:min(340px,72%);background:rgba(13,16,22,.74);backdrop-filter:blur(5px);border:1px solid var(--d-line);border-radius:12px;padding:10px 13px}
  .tm-feed h4{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--d-muted);margin-bottom:6px}
  .tm-feed ul{list-style:none;font-size:.76rem;min-height:96px}
  .tm-feed li{display:flex;gap:.5rem;align-items:baseline;padding:3px 0;animation:slideIn .3s ease}
  .tm-feed time{color:var(--d-muted);font-size:.7rem;font-variant-numeric:tabular-nums;min-width:54px}
  .tm-feed .bk{color:#27c08a;font-weight:800;font-size:.64rem;letter-spacing:.05em}
  .tm-note{font-size:.72rem;color:var(--d-muted);margin-top:16px;text-align:center}
  @media(max-width:680px){.tm-stats{grid-template-columns:repeat(2,1fr)}.tm-feed{display:none}}

  /* Section base */
  section.block{padding:78px 0}
  section.alt{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
  .section-head{text-align:center;max-width:680px;margin:0 auto 50px}
  .section-head h2{font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:900;margin:.5rem 0}
  .section-head p{color:var(--muted);font-size:1.05rem}

  /* Services */
  .services{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .card{
    background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;
    transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;
  }
  .card:hover{transform:translateY(-5px);border-color:var(--red);box-shadow:0 16px 30px rgba(20,23,29,.08)}
  .card .ico{
    width:48px;height:48px;border-radius:12px;display:grid;place-items:center;
    background:rgba(214,35,43,.10);margin-bottom:16px;font-size:1.4rem
  }
  .card h3{font-size:1.15rem;margin-bottom:.5rem}
  .card p{color:var(--muted);font-size:.94rem}
  @media(max-width:860px){.services{grid-template-columns:1fr}}

  /* Compliance band (dark) */
  .band{background:var(--black);border-top:1px solid var(--line);color:#fff}
  .band h2,.band h3{color:#fff}
  .band .eyebrow{color:#ff6b72}
  .band-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .band ul{list-style:none;margin-top:18px;display:grid;gap:12px}
  .band li{display:flex;gap:.7rem;color:#c5cad2}
  .band li b{color:#fff}
  .band-card{background:#1e222b;border:1px solid var(--d-line);border-radius:var(--radius);padding:26px}
  .band-card p{color:#aeb5bf}
  @media(max-width:860px){.band-grid{grid-template-columns:1fr}}

  /* Industries */
  .industries{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  .ind{border:1px solid var(--line);border-radius:var(--radius);padding:30px;background:var(--bg-soft);display:flex;flex-direction:column}
  .ind h3{font-size:1.3rem;margin-bottom:.5rem}
  .ind p{color:var(--muted)}
  .ind .badge{align-self:flex-start;margin-top:auto;padding-top:0;font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--red);background:rgba(255,49,49,.10);border:1px solid rgba(255,49,49,.25);padding:4px 10px;border-radius:999px}
  @media(max-width:860px){.industries{grid-template-columns:1fr}}

  /* CTA */
  .cta{text-align:center;background:var(--black);border-radius:24px;padding:56px 28px;color:#fff}
  .cta .eyebrow{color:#ff6b72}
  .cta h2{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:900;margin-bottom:.6rem;color:#fff}
  .cta p{color:#c5cad2;max-width:520px;margin:0 auto 1.6rem;font-size:1.05rem}

  /* Partners */
  .partners{text-align:center}
  .marquee{position:relative;overflow:hidden;margin-top:34px;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
    mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
  .marquee-track{display:flex;width:max-content;animation:scrollx 32s linear infinite}
  .marquee:hover .marquee-track{animation-play-state:paused}
  .marquee-group{display:flex;gap:22px;padding-right:22px}
  @keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  @media(prefers-reduced-motion:reduce){.marquee-track{animation:none}.marquee{overflow-x:auto}}
  .plogo{
    display:inline-flex;align-items:center;justify-content:center;
    height:64px;padding:0 22px;min-width:170px;
    background:#fff;border:1px solid var(--line);border-radius:12px;
    color:#6b7280;transition:color .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease;
  }
  .plogo:hover{color:#15181d;border-color:#15181d;transform:translateY(-3px);box-shadow:0 10px 22px rgba(20,23,29,.10)}
  .plogo svg{height:30px;width:auto;display:block;fill:currentColor}
  .plogo img{height:30px;width:auto;display:block;object-fit:contain}
  @media(max-width:520px){.plogo{min-width:140px;height:56px}}

  /* Footer */
  footer{background:#0f1116;border-top:1px solid var(--line);padding:56px 0 28px;color:#9aa3b1}
  .foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px}
  footer .logo{color:#fff}
  footer h4{color:#fff;font-size:.95rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
  footer a,footer p{display:block;font-size:.92rem;margin-bottom:8px}
  footer a:hover{color:#fff}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:36px;padding-top:20px;font-size:.85rem;text-align:center}
  @media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

  /* ===== Shared additions: nav dropdown + service pages ===== */
  .nav-links a.active{color:var(--ink)}
  .has-drop{position:relative}
  .has-drop>a::after{content:"\25BE";font-size:.7em;margin-left:.35em;opacity:.7}
  .dropdown{position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(6px);
    background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 40px rgba(20,23,29,.14);
    padding:8px;min-width:250px;opacity:0;visibility:hidden;transition:opacity .16s ease,transform .16s ease;z-index:60}
  .has-drop::before{content:"";position:absolute;top:100%;left:0;right:0;height:16px} /* hover bridge */
  .has-drop:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .dropdown a{display:block;padding:9px 12px;border-radius:9px;font-size:.92rem;color:var(--ink);font-weight:700}
  .dropdown a:hover{background:var(--bg-soft);color:var(--red)}
  .dropdown a small{display:block;font-weight:500;color:var(--muted);font-size:.78rem;margin-top:1px}

  /* Sub-page hero (dark) */
  .subhero{position:relative;overflow:hidden;color:#fff;
    background:radial-gradient(900px 520px at 85% -20%,rgba(255,49,49,.22),transparent 60%),linear-gradient(160deg,#1b1f27,#0f1116);
    border-bottom:1px solid var(--line);padding:72px 0}
  .subhero .eyebrow{color:#ff6b72}
  .subhero h1{color:#fff;font-size:clamp(2.1rem,4.6vw,3.2rem);font-weight:900;margin:.5rem 0 1rem}
  .subhero p.lead{color:#c5cad2;font-size:1.12rem;max-width:600px;margin-bottom:1.7rem}
  .subhero .hero-trust{color:#aeb5bf}
  .subhero .check{color:#27c08a}
  .breadcrumb{font-size:.8rem;color:#9aa3b1;margin-bottom:8px}
  .breadcrumb a:hover{color:#fff}

  /* Feature rows */
  .feature{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
  .feature .checklist{list-style:none;display:grid;gap:12px;margin-top:18px}
  .checklist li{display:flex;gap:.6rem;color:var(--muted)}
  .checklist li b{color:var(--ink)}
  .checklist .ck{color:var(--red);font-weight:900}
  @media(max-width:860px){.feature{grid-template-columns:1fr;gap:28px}}

  /* Media block */
  .media{border-radius:var(--radius);border:1px solid var(--line);overflow:hidden;
    background:linear-gradient(160deg,#eef0f4,#dfe3ea);min-height:300px;display:grid;place-items:center;color:var(--muted)}
  .media img{width:100%;height:100%;object-fit:cover;display:block}
  .media .ph{font-size:.85rem;letter-spacing:.04em}

  /* Process steps */
  .steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
  .step .num{width:38px;height:38px;border-radius:10px;background:var(--red);color:#fff;font-weight:900;display:grid;place-items:center;margin-bottom:14px}
  .step h3{font-size:1.05rem;margin-bottom:.4rem}
  .step p{color:var(--muted);font-size:.9rem}
  @media(max-width:860px){.steps{grid-template-columns:1fr 1fr}}
  @media(max-width:520px){.steps{grid-template-columns:1fr}}

  /* Stat band */
  .statband{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
  .statband .s b{display:block;font-size:2.2rem;font-weight:900;color:var(--ink);line-height:1}
  .statband .s span{color:var(--muted);font-size:.9rem;display:block;margin-top:6px}
  @media(max-width:680px){.statband{grid-template-columns:1fr 1fr;gap:22px}}


  /* Fluke Networks certification callout */
  .certcard{background:var(--d-bg);color:var(--d-ink);border:1px solid var(--d-line);border-radius:16px;padding:22px 22px 8px;box-shadow:0 24px 50px rgba(20,23,29,.18)}
  .certcard .ctop{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
  .certcard .ctop h4{color:#fff;font-size:1rem;margin:0}
  .certcard .ctop small{color:var(--d-muted);font-size:.72rem;display:block;margin-top:2px}
  .pass{display:inline-flex;align-items:center;gap:.35rem;font-size:.72rem;font-weight:800;letter-spacing:.06em;color:var(--ok);background:rgba(39,192,138,.12);padding:5px 11px;border-radius:999px;text-transform:uppercase}
  .certrow{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;border-top:1px solid var(--d-line);font-size:.85rem}
  .certrow .nm{color:var(--d-ink)}
  .certrow .ok{color:var(--ok);font-weight:800;font-size:.74rem;letter-spacing:.04em}
  .certrow .mg{color:var(--d-muted);font-variant-numeric:tabular-nums;font-size:.78rem;min-width:60px;text-align:right}
  .certcard .cfoot{color:var(--d-muted);font-size:.72rem;padding:10px 0 6px;border-top:1px solid var(--d-line);margin-top:2px;display:flex;align-items:center;gap:.4rem}

  /* Photo feature blocks (portrait job photos) + work gallery */
  .media{aspect-ratio:4/3;min-height:0}
  .media img{object-position:center}
  .gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .gallery a{display:block;border-radius:12px;overflow:hidden;border:1px solid var(--line);aspect-ratio:3/4;background:var(--bg-soft)}
  .gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}
  .gallery a:hover img{transform:scale(1.06)}
  @media(max-width:680px){.gallery{grid-template-columns:1fr 1fr}}

  /* Before / After compare slider */
  .ba-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(440px,1fr));gap:26px}
  .ba-item figcaption{margin-top:12px;text-align:center;color:var(--muted);font-size:.92rem;font-weight:600}
  .ba{position:relative;aspect-ratio:1200/670;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
      user-select:none;touch-action:none;cursor:ew-resize;--p:50%;background:#0f1116}
  .ba .ba-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
  .ba .ba-before{position:absolute;inset:0;clip-path:inset(0 calc(100% - var(--p)) 0 0)}
  .ba .ba-handle{position:absolute;top:0;bottom:0;left:var(--p);width:3px;background:#fff;transform:translateX(-1.5px);
      pointer-events:none;box-shadow:0 0 0 1px rgba(0,0,0,.18)}
  .ba .ba-handle b{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:42px;height:42px;border-radius:50%;
      background:#fff;box-shadow:0 3px 12px rgba(0,0,0,.35);display:grid;place-items:center;color:var(--ink);font-size:.9rem;font-weight:900;letter-spacing:-1px}
  .ba .ba-tag{position:absolute;top:12px;font-size:.68rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
      color:#fff;background:rgba(13,16,22,.72);padding:5px 11px;border-radius:999px;pointer-events:none}
  .ba .ba-b{left:12px}
  .ba .ba-a{right:12px}
  @media(max-width:680px){.ba-grid{grid-template-columns:1fr}}

  /* Portrait before/after (tall floor racks) */
  .ba-solo{max-width:470px;margin:26px auto 0}
  .ba-solo .ba{aspect-ratio:3/4}

  /* Kortech brand watermark on dark NOC / status cards */
  .brandmark{position:absolute;right:16px;bottom:13px;height:14px;width:auto;opacity:.62;pointer-events:none;user-select:none}
  .noc{position:relative}
  .noc .brandmark{top:20px;right:20px;bottom:auto;height:15px;opacity:.7}
  .certcard{position:relative}
  .tm-feed .brandmark{top:10px;right:12px;bottom:auto;height:12px;opacity:.7}

  /* Wi-Fi heat map gallery (masonry, preserves full aspect) */
  .hm-gallery{column-count:3;column-gap:16px}
  .hm-gallery figure{margin:0 0 16px;break-inside:avoid}
  .hm-gallery a{display:block;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:0 8px 22px rgba(20,23,29,.06);transition:box-shadow .2s ease,transform .2s ease}
  .hm-gallery a:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(20,23,29,.12)}
  .hm-gallery img{width:100%;display:block}
  .hm-gallery figcaption{font-size:.82rem;color:var(--muted);font-weight:600;padding:8px 2px 0}
  @media(max-width:900px){.hm-gallery{column-count:2}}
  @media(max-width:560px){.hm-gallery{column-count:1}}

  /* override: uniform grid for heat map gallery (removes masonry gaps) */
  .hm-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;column-count:auto}
  .hm-gallery figure{margin:0}
  .hm-gallery a{aspect-ratio:4/3}
  .hm-gallery img{height:100%;object-fit:cover;object-position:center}
  @media(max-width:900px){.hm-gallery{grid-template-columns:1fr 1fr}}
  @media(max-width:560px){.hm-gallery{grid-template-columns:1fr}}

  /* Compliance page: framework cards + comparison table */
  .fw-badge{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--red);background:rgba(255,49,49,.10);border:1px solid rgba(255,49,49,.25);padding:4px 10px;border-radius:999px;margin-bottom:14px}
  .card .mini{list-style:none;margin-top:14px;display:grid;gap:8px}
  .card .mini li{display:flex;gap:.5rem;color:var(--muted);font-size:.9rem}
  .card .mini .ck{color:var(--red);font-weight:900;flex:none}
  .card .howwe{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-size:.9rem;color:var(--ink)}
  .card .howwe b{color:var(--red)}
  .cmp-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}
  .cmp{width:100%;border-collapse:collapse;font-size:.92rem;min-width:680px}
  .cmp th,.cmp td{text-align:left;padding:15px 18px;border-bottom:1px solid var(--line);vertical-align:top}
  .cmp thead th{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:var(--bg-soft);font-weight:800}
  .cmp tbody th{font-weight:800;color:var(--ink);white-space:nowrap}
  .cmp td{color:var(--muted)}
  .cmp tbody tr:last-child td,.cmp tbody tr:last-child th{border-bottom:0}

  /* Threat map: firewall "defended by" row */
  .fwbar{margin-bottom:22px;text-align:center}
  .fwbar .cap{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--d-muted);font-weight:800;margin-bottom:12px}
  .fwlogos{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
  .fwchip{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--d-line);border-radius:12px;padding:12px 20px;min-width:210px;justify-content:center}
  .fwchip img{height:24px;width:auto;display:block;flex:none}
  .fwchip .m{font-weight:800;color:#15181d;font-size:.92rem;white-space:nowrap}
  @media(max-width:620px){.fwchip{min-width:0;flex:1 1 42%;padding:10px 12px;gap:8px}.fwchip .m{font-size:.8rem}}

  /* enlarge firewall chip logos for readability */
  .fwchip{min-width:230px;padding:12px 22px}
  .fwchip img{height:30px}

  /* Video showcase (surveillance) */
  .vidframe{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#000;box-shadow:0 18px 40px rgba(20,23,29,.08)}
  .vidframe video{width:100%;height:auto;display:block}
  .vidnote{text-align:center;color:var(--muted);font-size:.82rem;margin-top:14px}

  /* Contact page: form + info */
  .contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:42px;align-items:start}
  @media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:30px}}
  .cinfo .item{display:flex;gap:.8rem;margin-bottom:20px}
  .cinfo .item .ic{font-size:1.25rem;flex:none;line-height:1.2}
  .cinfo .item b{display:block;color:var(--ink);margin-bottom:2px}
  .cinfo .item span,.cinfo .item a{color:var(--muted);font-size:.95rem}
  .cinfo .item a:hover{color:var(--red)}
  .cform{display:grid;gap:15px}
  .cform .row{display:grid;grid-template-columns:1fr 1fr;gap:15px}
  @media(max-width:560px){.cform .row{grid-template-columns:1fr}}
  .cform label{font-size:.8rem;font-weight:700;color:var(--ink);display:block;margin-bottom:6px}
  .cform input,.cform textarea{width:100%;padding:12px 14px;border:1px solid var(--line-strong);border-radius:10px;font:inherit;font-size:.95rem;background:#fff;color:var(--ink)}
  .cform input:focus,.cform textarea:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(255,49,49,.12)}
  .cform textarea{min-height:140px;resize:vertical}
  .cform .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
  .cform .formnote{font-size:.78rem;color:var(--muted)}
  .mapframe{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-top:8px}
  .mapframe iframe{width:100%;height:340px;border:0;display:block}
  /* About values */
  .vgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
  @media(max-width:680px){.vgrid{grid-template-columns:1fr}}
