/* ============================================================
   Alrafioo Corporation — Public Site  (v4 redesign)
   Industrial control-room aesthetic. Steel-blue base,
   ISA-aware accent palette, engineering type system.
   Custom CSS, mobile-first, no framework.
   ============================================================ */

:root{
  /* Steel-blue control-room palette */
  --bg:#141f33;
  --bg2:#18243b;
  --bg3:#1f2f4c;
  --panel:#26395c;
  --panel2:#2e436b;
  --panel-hi:#33486f;
  --line:rgba(124,166,219,0.20);
  --line-soft:rgba(124,166,219,0.11);
  --line-strong:rgba(124,166,219,0.40);

  --text:#eef5ff;
  --text-dim:#aebfda;
  --text-mut:#7587aa;

  --green:#1fe07a;
  --green-deep:#0e9d52;
  --green-glow:rgba(31,224,122,0.55);
  --cyan:#33d6ee;
  --cyan-glow:rgba(51,214,238,0.45);
  --amber:#ffb53d;
  --amber-glow:rgba(255,181,61,0.45);
  --red:#ff6b6b;
  --blue:#4fa3ff;
  --orange:#ff9355;
  --yellow:#fbc52f;
  --brown:#c2876f;

  /* legacy aliases so older inline styles never break */
  --bg-2:var(--bg2);
  --panel-2:var(--panel2);

  --radius:14px;
  --radius-sm:9px;
  --mono:"IBM Plex Mono",ui-monospace,Menlo,Consolas,monospace;
  --sans:"IBM Plex Sans","Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  --display:"Saira","IBM Plex Sans",system-ui,sans-serif;

  --max:1320px;
  --pad:clamp(16px,3vw,30px);
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 22px 50px -18px rgba(0,0,0,.55);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;padding:0;font-family:var(--sans);
  background:
    radial-gradient(1300px 640px at 80% -12%, rgba(31,224,122,0.08), transparent 60%),
    radial-gradient(1000px 560px at 0% 100%, rgba(51,214,238,0.07), transparent 65%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
  background-attachment:fixed;
  color:var(--text);font-size:15.5px;line-height:1.65;
  overflow-x:hidden;min-height:100vh;-webkit-font-smoothing:antialiased;
}
/* faint engineering grid behind everything */
body::before{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:
    linear-gradient(rgba(124,166,219,0.035) 1px,transparent 1px),
    linear-gradient(90deg,rgba(124,166,219,0.035) 1px,transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(circle at 50% 16%, #000 0%, transparent 78%);
  -webkit-mask-image:radial-gradient(circle at 50% 16%, #000 0%, transparent 78%);
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(31,224,122,.28);color:#fff}

/* ---------- Layout ---------- */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:clamp(58px,8vw,96px) var(--pad);max-width:var(--max);margin:0 auto;position:relative}
.section.alt{
  background:linear-gradient(180deg,rgba(31,47,76,.55),rgba(24,36,59,.35));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  max-width:none;padding-left:0;padding-right:0;
}
.section.alt > .inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* =========================================================
   TOP STATUS BAR + NAV
   ========================================================= */
.statusbar{
  background:linear-gradient(90deg,var(--bg3),var(--bg2));
  border-bottom:1px solid var(--line-soft);
  font-family:var(--mono);font-size:11.5px;color:var(--text-dim);
  letter-spacing:.4px;
}
.statusbar .row{
  max-width:var(--max);margin:0 auto;padding:6px var(--pad);
  display:flex;align-items:center;gap:18px;height:34px;overflow:hidden;
}
.statusbar .sb-item{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.statusbar .sb-item b{color:var(--text);font-weight:600}
.statusbar .live{color:var(--green)}
.statusbar .live::before{
  content:"";width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 8px var(--green-glow);animation:pulse 2.6s infinite;
}
.statusbar .sep{flex:1}
.statusbar .sb-right{display:flex;gap:18px;align-items:center}
.statusbar a:hover{color:var(--green)}
@media (max-width:760px){.statusbar .sb-hide{display:none}}

.topnav{
  position:sticky;top:0;z-index:60;
  background:rgba(20,31,51,0.78);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);
  transition:padding .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease);
}
.topnav.scrolled{
  background:rgba(18,28,46,0.92);
  box-shadow:0 14px 34px -20px rgba(0,0,0,.7);
}
.topnav .row{
  display:flex;align-items:center;gap:18px;height:74px;
  max-width:var(--max);margin:0 auto;padding:0 var(--pad);
  transition:height .3s var(--ease);
}
.topnav.scrolled .row{height:62px}

/* ---------- Logo ---------- */
.logo{display:flex;align-items:center;gap:13px}
.logo .mark{
  width:42px;height:42px;flex-shrink:0;display:block;
  transition:transform .5s var(--ease);
}
.topnav.scrolled .logo .mark{width:37px;height:37px}
.logo:hover .mark{transform:rotate(8deg) scale(1.04)}
.logo .mark .ring{transform-origin:32px 32px;animation:spin 22s linear infinite}
.logo .mark .needle{transform-origin:32px 32px;animation:logoSweep 6s var(--ease) infinite}
.logo .mark .core{animation:pulse 2.6s infinite}
.logo .word{display:flex;flex-direction:column;line-height:1}
.logo .word .name{
  font-family:var(--display);font-weight:800;font-size:21px;letter-spacing:.5px;
  color:var(--text);
}
.logo .word .name i{font-style:normal;color:var(--green)}
.logo .word .sub{
  font-family:var(--mono);font-size:9.5px;letter-spacing:3.2px;
  color:var(--text-mut);margin-top:3px;font-weight:500;
}

/* ---------- Nav links ---------- */
.nav-links{display:flex;gap:3px;align-items:center;margin-left:auto}
.nav-links a.lnk{
  position:relative;padding:10px 15px;border-radius:8px;color:var(--text-dim);
  font-size:14.5px;font-weight:500;transition:color .2s var(--ease);
}
.nav-links a.lnk::after{
  content:"";position:absolute;left:15px;right:15px;bottom:6px;height:2px;
  background:linear-gradient(90deg,var(--green),var(--cyan));
  transform:scaleX(0);transform-origin:left;border-radius:2px;
  transition:transform .28s var(--ease);
}
.nav-links a.lnk:hover{color:var(--text)}
.nav-links a.lnk:hover::after,.nav-links a.lnk.active::after{transform:scaleX(1)}
.nav-links a.lnk.active{color:var(--text)}

.nav-cta{
  margin-left:10px;position:relative;overflow:hidden;
  display:inline-flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--green),var(--green-deep));
  color:#042914 !important;font-weight:700;padding:10px 18px;border-radius:9px;
  font-size:14px;box-shadow:0 8px 22px -8px var(--green-glow);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 14px 30px -8px var(--green-glow)}
.nav-cta::before{
  content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-20deg);transition:left .6s var(--ease);
}
.nav-cta:hover::before{left:160%}

/* ---------- Hamburger ---------- */
.nav-toggle{
  display:none;background:var(--panel);border:1px solid var(--line);
  width:44px;height:44px;border-radius:10px;cursor:pointer;margin-left:auto;
  padding:0;position:relative;
}
.nav-toggle span{
  position:absolute;left:11px;right:11px;height:2px;background:var(--text);
  border-radius:2px;transition:.3s var(--ease);
}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:21px}
.nav-toggle span:nth-child(3){top:28px}
.nav-toggle.x span:nth-child(1){top:21px;transform:rotate(45deg)}
.nav-toggle.x span:nth-child(2){opacity:0}
.nav-toggle.x span:nth-child(3){top:21px;transform:rotate(-45deg)}

@media (max-width:940px){
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    background:rgba(18,28,46,.98);backdrop-filter:blur(16px);
    flex-direction:column;align-items:stretch;gap:2px;
    padding:14px var(--pad) 18px;border-bottom:1px solid var(--line);
    margin-left:0;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:.3s var(--ease);max-height:calc(100vh - 74px);overflow:auto;
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a.lnk{padding:13px 14px;border-radius:9px;font-size:15.5px}
  .nav-links a.lnk::after{display:none}
  .nav-links a.lnk:hover,.nav-links a.lnk.active{background:rgba(255,255,255,.05)}
  .nav-cta{margin:8px 0 0;justify-content:center;padding:14px}
}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:13px 24px;border-radius:10px;font-size:15px;font-weight:600;
  font-family:var(--sans);
  border:1px solid var(--line-strong);background:var(--panel);color:var(--text);
  cursor:pointer;position:relative;overflow:hidden;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease);
}
.btn::before{
  content:"";position:absolute;top:0;left:-120%;width:50%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.22),transparent);
  transform:skewX(-20deg);transition:left .6s var(--ease);
}
.btn:hover::before{left:170%}
.btn:hover{transform:translateY(-2px);border-color:var(--green);background:var(--panel2);box-shadow:var(--shadow)}
.btn:active{transform:translateY(0)}
.btn.primary{background:linear-gradient(135deg,var(--green),var(--green-deep));border-color:transparent;color:#042914;box-shadow:0 10px 26px -10px var(--green-glow)}
.btn.primary:hover{box-shadow:0 16px 34px -10px var(--green-glow)}
.btn.wa{background:linear-gradient(135deg,#25D366,#128C7E);border-color:transparent;color:#042914;box-shadow:0 10px 26px -10px rgba(37,211,102,.55)}
.btn.wa:hover{box-shadow:0 16px 34px -10px rgba(37,211,102,.55)}
.btn.lg{padding:15px 30px;font-size:16px}
.btn.sm{padding:9px 17px;font-size:13.5px}
.btn.ghost{background:transparent}
.btn svg{transition:transform .2s var(--ease)}
.btn:hover svg{transform:translateX(2px)}

/* =========================================================
   HERO
   ========================================================= */
.hero{padding:clamp(36px,5vw,64px) var(--pad) clamp(54px,7vw,80px);max-width:var(--max);margin:0 auto;position:relative}
.hero-grid{display:grid;grid-template-columns:5fr 7fr;gap:clamp(28px,4vw,52px);align-items:center}
@media (max-width:1080px){.hero-grid{grid-template-columns:1fr;gap:38px}}

/* staggered load-in */
.hero [data-rise]{opacity:0;transform:translateY(22px);animation:rise .8s var(--ease) forwards}
.hero [data-rise="1"]{animation-delay:.05s}
.hero [data-rise="2"]{animation-delay:.16s}
.hero [data-rise="3"]{animation-delay:.27s}
.hero [data-rise="4"]{animation-delay:.38s}
.hero [data-rise="5"]{animation-delay:.5s}
.hero .scada{opacity:0;transform:translateY(26px) scale(.99);animation:rise .9s var(--ease) .3s forwards}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--mono);font-size:11px;letter-spacing:2.4px;color:var(--green);
  padding:7px 15px;border:1px solid rgba(31,224,122,0.32);
  border-radius:999px;background:rgba(31,224,122,0.06);margin-bottom:24px;text-transform:uppercase;
}
.hero-eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--green);box-shadow:0 0 10px var(--green-glow);animation:pulse 2.6s infinite;
}
.hero h1{
  font-family:var(--display);font-weight:800;
  font-size:clamp(38px,5.2vw,66px);line-height:1.02;letter-spacing:-.01em;
  margin:0 0 22px;
}
.hero h1 .accent{
  background:linear-gradient(100deg,var(--green) 0%,var(--cyan) 52%,var(--blue) 100%);
  background-size:200% auto;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:shimmer 7s linear infinite;
}
.hero p.lead{font-size:17.5px;color:var(--text-dim);margin:0 0 32px;max-width:540px;line-height:1.7}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:34px}

/* spec strip / stat cells */
.spec-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.spec-strip .cell{background:linear-gradient(180deg,var(--panel),var(--panel2));padding:18px 20px;position:relative}
.spec-strip .cell::after{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:currentColor;opacity:.35}
.spec-strip .cell .lbl{
  font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:2px;
  color:var(--text-mut);text-transform:uppercase;
}
.spec-strip .cell .val{
  font-size:30px;font-weight:800;font-variant-numeric:tabular-nums;
  margin-top:6px;font-family:var(--display);letter-spacing:-.01em;
}
.spec-strip .cell.g{color:var(--green)} .spec-strip .cell.g .val{color:var(--green)}
.spec-strip .cell.c{color:var(--cyan)}  .spec-strip .cell.c .val{color:var(--cyan)}
.spec-strip .cell.a{color:var(--amber)} .spec-strip .cell.a .val{color:var(--amber)}

/* =========================================================
   SCADA PANEL  (signature instrument)
   ========================================================= */
.scada{
  background:linear-gradient(180deg, var(--bg3) 0%, var(--bg2) 100%);
  border:1px solid var(--line);border-radius:16px;
  padding:18px;position:relative;overflow:hidden;
  box-shadow:0 40px 80px -28px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.05);
}
.scada::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(124,166,219,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(124,166,219,0.06) 1px, transparent 1px);
  background-size:24px 24px;
  mask-image:radial-gradient(circle at 50% 30%, #000 55%, transparent 95%);
  -webkit-mask-image:radial-gradient(circle at 50% 30%, #000 55%, transparent 95%);
}
.scada-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;position:relative;z-index:1;flex-wrap:wrap}
.scada-header .tag{
  font-family:var(--mono);font-size:10px;color:var(--cyan);letter-spacing:1.5px;
  background:rgba(51,214,238,0.1);padding:3px 8px;border-radius:5px;
  border:1px solid rgba(51,214,238,0.3);font-weight:700;
}
.scada-header .title{font-size:13px;font-weight:700;color:var(--text);letter-spacing:1.5px;text-transform:uppercase}
.scada-header .title::before{content:"▸ ";color:var(--cyan)}
.scada-header .unit{font-family:var(--mono);font-size:11px;color:var(--text-mut);letter-spacing:1.5px}
.scada-header .clock{margin-left:auto;color:var(--green);font-family:var(--mono);font-size:13px;font-variant-numeric:tabular-nums;font-weight:600}
.scada-header .led-row{display:flex;gap:5px}
.scada-header .led-row .l{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green-glow)}
.scada-header .led-row .l.a{background:var(--amber);box-shadow:0 0 6px var(--amber)}
.scada-header .led-row .l.off{background:var(--text-mut);box-shadow:none;opacity:.5}

.gauges{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;position:relative;z-index:1;margin-bottom:14px}
.gauge{background:rgba(20,31,51,0.55);border:1px solid var(--line-soft);border-radius:11px;padding:10px 12px 12px}
.gauge .lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:1.3px;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px;display:flex;justify-content:space-between;font-weight:600}
.gauge .lbl b{font-weight:700}
.gauge-svg{width:100%;height:auto;display:block}
.gauge .readout{text-align:center;font-family:var(--display);font-weight:700;font-size:19px;font-variant-numeric:tabular-nums;margin-top:-12px}
.gauge .readout .u{font-size:11px;color:var(--text-dim);font-weight:400;margin-left:3px}
.gauge.g .readout{color:var(--green)} .gauge.c .readout{color:var(--cyan)} .gauge.a .readout{color:var(--amber)}

.pid-section{position:relative;z-index:1;background:rgba(20,31,51,0.5);border:1px solid var(--line-soft);border-radius:11px;padding:14px;margin-bottom:14px}
.pid-svg{width:100%;height:auto;display:block}
.pid-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;font-family:var(--mono);font-size:10.5px;color:var(--text-dim);letter-spacing:.6px;font-weight:600}
.pid-legend .item{display:flex;align-items:center;gap:6px}
.pid-legend .dot{width:12px;height:3px;border-radius:1px}

.bottom-row{display:grid;grid-template-columns:3fr 2fr;gap:10px;position:relative;z-index:1}
@media (max-width:620px){.bottom-row{grid-template-columns:1fr}}
.trend{background:rgba(20,31,51,0.5);border:1px solid var(--line-soft);border-radius:11px;padding:12px}
.trend-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:10px;flex-wrap:wrap}
.trend-head .l{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--text);letter-spacing:1px;text-transform:uppercase}
.trend-head .l .id{font-family:var(--mono);font-size:10px;color:var(--cyan);background:rgba(51,214,238,0.1);padding:2px 7px;border-radius:5px;border:1px solid rgba(51,214,238,0.3);font-weight:700}
.trend-head .v{font-family:var(--mono);font-size:11px;color:var(--green);font-variant-numeric:tabular-nums;font-weight:600}
.trend-svg{width:100%;height:90px;display:block}

.valves{background:rgba(20,31,51,0.5);border:1px solid var(--line-soft);border-radius:11px;padding:12px}
.valves-head{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--text);letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.valves-head .id{font-family:var(--mono);font-size:10px;color:var(--cyan);background:rgba(51,214,238,0.1);padding:2px 7px;border-radius:5px;border:1px solid rgba(51,214,238,0.3);font-weight:700}
.valve-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.valve-btn{background:rgba(20,31,51,0.6);border:1px solid var(--line-soft);border-radius:9px;padding:9px 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:5px;transition:.18s var(--ease);font-family:var(--mono);color:inherit}
.valve-btn:hover{background:var(--panel2);border-color:var(--line-strong);transform:translateY(-1px)}
.valve-btn.open{background:rgba(31,224,122,0.1);border-color:rgba(31,224,122,0.4)}
.valve-btn.closed{background:rgba(255,107,107,0.08);border-color:rgba(255,107,107,0.35)}
.valve-svg{width:36px;height:36px;display:block}
.valve-btn .name{font-size:10px;letter-spacing:.5px;color:var(--text-dim);font-weight:600;text-transform:uppercase}
.valve-btn .state{font-size:9px;letter-spacing:1px;font-weight:600}
.valve-btn.open .state{color:var(--green)} .valve-btn.closed .state{color:var(--red)}

/* =========================================================
   SECTION HEADS + KICKERS  (no more terminal // comments)
   ========================================================= */
.section-head{margin-bottom:46px;max-width:780px}
.section-head.row{display:flex;align-items:end;gap:20px;flex-wrap:wrap;max-width:none;margin-bottom:40px}
.section-head.row > div{flex:1;min-width:280px}
.section-head.row h2{margin:0}

.kicker{
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--display);
  font-size:13.5px;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;margin-bottom:18px;color:var(--green);
}
.kicker .num{
  font-family:var(--mono);font-size:11px;font-weight:700;
  padding:4px 9px;border-radius:5px;letter-spacing:1.5px;
  background:rgba(31,224,122,0.12);border:1px solid rgba(31,224,122,0.4);color:var(--green);
}
.kicker::before{content:"▸"}
.kicker.cy{color:var(--cyan)} .kicker.cy .num{background:rgba(51,214,238,0.12);border-color:rgba(51,214,238,0.35);color:var(--cyan)}
.kicker.am{color:var(--amber)} .kicker.am .num{background:rgba(255,181,61,0.12);border-color:rgba(255,181,61,0.4);color:var(--amber)}
.kicker.gr{color:var(--green)} .kicker.gr .num{background:rgba(31,224,122,0.12);border-color:rgba(31,224,122,0.4);color:var(--green)}
.kicker.bl{color:var(--blue)} .kicker.bl .num{background:rgba(79,163,255,0.12);border-color:rgba(79,163,255,0.4);color:var(--blue)}

.section-head h2{
  font-family:var(--display);font-size:clamp(28px,3.7vw,44px);
  font-weight:800;letter-spacing:-.01em;margin:0 0 14px;line-height:1.08;
}
.section-head h1{
  font-family:var(--display);font-size:clamp(32px,5vw,52px);
  font-weight:800;letter-spacing:-.01em;margin:0 0 16px;line-height:1.05;
}
.section-head p{color:var(--text-dim);max-width:640px;font-size:16.5px;margin:0;line-height:1.7}

/* =========================================================
   STAT BAND (animated counters)
   ========================================================= */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
@media (max-width:720px){.stat-band{grid-template-columns:1fr 1fr}}
.stat-band .s{background:linear-gradient(180deg,var(--panel),var(--panel2));padding:30px 22px;position:relative;overflow:hidden}
.stat-band .s::before{content:"";position:absolute;inset:0;background:radial-gradient(120px 80px at 80% 0,rgba(31,224,122,.1),transparent 70%);opacity:0;transition:opacity .3s}
.stat-band .s:hover::before{opacity:1}
.stat-band .s .big{font-family:var(--display);font-size:clamp(34px,4vw,46px);font-weight:800;letter-spacing:-.02em;line-height:1;font-variant-numeric:tabular-nums}
.stat-band .s .cap{font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--text-mut);margin-top:10px}
.stat-band .s.g .big{color:var(--green)} .stat-band .s.c .big{color:var(--cyan)}
.stat-band .s.a .big{color:var(--amber)} .stat-band .s.b .big{color:var(--blue)}

/* =========================================================
   CARD GRIDS
   ========================================================= */
.cards{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.cap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:980px){.cap-grid,.prod-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.cap-grid,.prod-grid{grid-template-columns:1fr}}

.card{
  background:linear-gradient(180deg,var(--panel),var(--panel2));
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);
  display:flex;flex-direction:column;position:relative;
}
.card::after{content:"";position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--green),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.card:hover{transform:translateY(-5px);border-color:rgba(31,224,122,.4);box-shadow:var(--shadow)}
.card:hover::after{transform:scaleX(1)}
.card .media{aspect-ratio:4/3;background:rgba(20,31,51,0.6);display:grid;place-items:center;color:var(--text-mut);font-family:var(--mono);font-size:10px;letter-spacing:2px;border-bottom:1px solid var(--line-soft);position:relative;overflow:hidden}
.card .media img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.card:hover .media img{transform:scale(1.05)}
.card .media .tag-corner{position:absolute;top:9px;left:9px;font-family:var(--mono);font-size:9px;color:var(--cyan);letter-spacing:1.5px;background:rgba(20,31,51,0.85);padding:3px 8px;border-radius:5px;border:1px solid rgba(51,214,238,0.3);font-weight:700}
.card .body{padding:18px 18px 20px;flex:1;display:flex;flex-direction:column}
.card h3{font-size:16.5px;font-weight:700;margin:0 0 8px;letter-spacing:-.01em;font-family:var(--display)}
.card h4{font-size:15px;font-weight:700;margin:0 0 8px;line-height:1.3;font-family:var(--display)}
.card .meta{font-family:var(--mono);font-size:10px;letter-spacing:1.4px;color:var(--text-mut);margin-bottom:7px;text-transform:uppercase;font-weight:600}
.card p{color:var(--text-dim);font-size:13.8px;margin:0 0 16px;flex:1;line-height:1.6}
.card .more{display:inline-flex;align-items:center;gap:6px;color:var(--green);font-size:13px;font-weight:700;margin-top:auto}
.card .more::after{content:"→";transition:transform .2s var(--ease)}
.card:hover .more::after{transform:translateX(4px)}

/* capability cards */
.cap{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);padding:24px;transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);position:relative;overflow:hidden}
.cap::before{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(31,224,122,.12),transparent 70%);opacity:0;transition:opacity .3s}
.cap:hover{transform:translateY(-5px);border-color:rgba(31,224,122,.4);box-shadow:var(--shadow)}
.cap:hover::before{opacity:1}
.cap .ic{width:50px;height:50px;border-radius:12px;background:rgba(31,224,122,0.12);display:grid;place-items:center;margin-bottom:16px;border:1px solid rgba(31,224,122,0.3);transition:transform .3s var(--ease)}
.cap:hover .ic{transform:scale(1.08) rotate(-4deg)}
.cap.cy .ic{background:rgba(51,214,238,0.12);border-color:rgba(51,214,238,0.3)}
.cap.am .ic{background:rgba(255,181,61,0.12);border-color:rgba(255,181,61,0.3)}
.cap.bl .ic{background:rgba(79,163,255,0.12);border-color:rgba(79,163,255,0.3)}
.cap .meta{font-family:var(--mono);font-size:10px;letter-spacing:2px;color:var(--text-mut);margin-bottom:8px;text-transform:uppercase;font-weight:600}
.cap h3{font-size:18px;font-weight:700;margin:0 0 8px;font-family:var(--display)}
.cap p{color:var(--text-dim);font-size:13.8px;margin:0 0 16px;line-height:1.6}
.cap .more{color:var(--green);font-size:13px;font-weight:700;display:inline-flex;gap:6px}
.cap .more::after{content:"→";transition:transform .2s var(--ease)}
.cap:hover .more::after{transform:translateX(4px)}
.cap.cy .more{color:var(--cyan)} .cap.am .more{color:var(--amber)} .cap.bl .more{color:var(--blue)}

/* =========================================================
   WHY-CHOOSE / FEATURE TILES
   ========================================================= */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:860px){.why-grid{grid-template-columns:1fr}}
.why{display:flex;gap:16px;padding:22px;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);transition:transform .25s var(--ease),border-color .25s var(--ease)}
.why:hover{transform:translateY(-3px);border-color:var(--line-strong)}
.why .ic{flex-shrink:0;width:46px;height:46px;border-radius:11px;background:rgba(51,214,238,.1);border:1px solid rgba(51,214,238,.3);display:grid;place-items:center}
.why h4{margin:0 0 6px;font-size:16px;font-family:var(--display);font-weight:700}
.why p{margin:0;color:var(--text-dim);font-size:13.8px;line-height:1.6}

/* =========================================================
   PROCESS TIMELINE
   ========================================================= */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;counter-reset:step;position:relative}
@media (max-width:860px){.process{grid-template-columns:1fr;gap:8px}}
.process .step{position:relative;padding:24px 22px;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);transition:.25s var(--ease)}
.process .step:first-child{border-radius:var(--radius) 0 0 var(--radius)}
.process .step:last-child{border-radius:0 var(--radius) var(--radius) 0}
@media (max-width:860px){.process .step,.process .step:first-child,.process .step:last-child{border-radius:var(--radius)}}
.process .step:not(:last-child){border-right:none}
@media (max-width:860px){.process .step:not(:last-child){border-right:1px solid var(--line)}}
.process .step:hover{background:var(--panel2);transform:translateY(-3px);z-index:2;border-color:var(--line-strong)}
.process .step .n{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--green);background:rgba(31,224,122,.12);border:1px solid rgba(31,224,122,.4);width:34px;height:34px;border-radius:9px;display:grid;place-items:center;margin-bottom:14px}
.process .step h4{margin:0 0 7px;font-size:16px;font-family:var(--display);font-weight:700}
.process .step p{margin:0;color:var(--text-dim);font-size:13.5px;line-height:1.6}

/* =========================================================
   BRAND STRIP
   ========================================================= */
.brand-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:780px){.brand-strip{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.brand-strip{grid-template-columns:1fr}}
.brand-cell{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:12px;padding:26px 18px 20px;text-align:center;position:relative;border-top:3px solid var(--line-strong);transition:transform .22s var(--ease),box-shadow .22s var(--ease)}
.brand-cell:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.brand-cell .name{font-size:19px;font-weight:800;letter-spacing:1.5px;color:var(--text);font-family:var(--display)}
.brand-cell .auth{margin-top:9px;display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:1.4px;color:var(--green);padding:4px 11px;border:1px solid rgba(31,224,122,0.4);border-radius:999px;background:rgba(31,224,122,0.08)}
.brand-cell .auth::before{content:"✓";color:var(--green);font-weight:bold}

/* =========================================================
   CLIENT GRID
   ========================================================= */
.client-grid{display:grid;gap:1px;background:var(--line);grid-template-columns:repeat(auto-fill,minmax(165px,1fr));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.client-grid .cell{background:linear-gradient(180deg,var(--panel),var(--panel2));aspect-ratio:3/2;display:grid;place-items:center;padding:18px;color:var(--text-dim);font-family:var(--display);font-weight:600;font-size:14px;text-align:center;transition:.2s var(--ease)}
.client-grid .cell:hover{background:var(--panel-hi);color:var(--text)}
.client-grid .cell img{max-height:60px;max-width:100%;object-fit:contain;filter:grayscale(.3)}
.client-grid .cell:hover img{filter:grayscale(0)}

/* =========================================================
   TEAM / LEADERSHIP
   ========================================================= */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:860px){.team-grid{grid-template-columns:1fr}}
.member{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:relative;overflow:hidden;transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease)}
.member:hover{transform:translateY(-4px);border-color:rgba(31,224,122,.4);box-shadow:var(--shadow)}
.member .avatar{width:74px;height:74px;border-radius:16px;display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:27px;color:#042914;background:linear-gradient(135deg,var(--green),var(--cyan));margin-bottom:16px;box-shadow:0 10px 24px -10px var(--green-glow)}
.member.c .avatar{background:linear-gradient(135deg,var(--cyan),var(--blue))}
.member.a .avatar{background:linear-gradient(135deg,var(--amber),var(--orange));color:#3a1d00}
.member .name{font-family:var(--display);font-size:19px;font-weight:700;margin:0 0 3px}
.member .role{font-family:var(--mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.member.c .role{color:var(--cyan)} .member.a .role{color:var(--amber)}
.member p{margin:0;color:var(--text-dim);font-size:14px;line-height:1.65}
.member .creds{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.member .creds span{font-family:var(--mono);font-size:10px;letter-spacing:.5px;color:var(--text-dim);padding:3px 9px;border:1px solid var(--line);border-radius:999px;background:rgba(20,31,51,.4)}

/* =========================================================
   DETAIL PAGES + SPEC PANELS
   ========================================================= */
.detail{display:grid;gap:38px;grid-template-columns:5fr 4fr;align-items:start}
@media (max-width:880px){.detail{grid-template-columns:1fr}}
.detail .photo{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;display:grid;place-items:center;color:var(--text-mut);font-family:var(--mono);position:relative}
.detail .photo img{width:100%;height:100%;object-fit:cover}
.detail .photo .ph-badge{position:absolute;left:14px;top:14px;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;color:var(--cyan);background:rgba(20,31,51,.85);border:1px solid rgba(51,214,238,.3);padding:4px 10px;border-radius:6px;font-weight:700}
.detail h1{font-family:var(--display);font-size:clamp(26px,4vw,40px);font-weight:800;margin:0 0 8px;line-height:1.12}

.meta-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.tag{display:inline-block;padding:5px 12px;border-radius:999px;font-family:var(--mono);font-size:11px;letter-spacing:.8px;background:rgba(31,224,122,.14);color:var(--green);border:1px solid rgba(31,224,122,.3);font-weight:600}
.tag.cyan{background:rgba(51,214,238,.14);color:var(--cyan);border-color:rgba(51,214,238,.3)}
.tag.amber{background:rgba(255,181,61,.14);color:var(--amber);border-color:rgba(255,181,61,.3)}

/* spec table */
.spec-table{width:100%;border-collapse:collapse;margin:6px 0 4px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.spec-table caption{caption-side:top;text-align:left;font-family:var(--display);font-weight:700;font-size:15px;color:var(--text);padding:0 0 12px;display:flex;align-items:center;gap:8px}
.spec-table tr{border-bottom:1px solid var(--line-soft)}
.spec-table tr:last-child{border-bottom:none}
.spec-table tr:nth-child(odd){background:rgba(20,31,51,.35)}
.spec-table th{text-align:left;padding:12px 16px;font-family:var(--mono);font-size:11.5px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-mut);font-weight:600;width:42%;vertical-align:top}
.spec-table td{padding:12px 16px;font-size:14.5px;color:var(--text);font-weight:500}
.spec-table td .ok{color:var(--green);font-weight:700}

/* feature checklist */
.feature-list{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:10px}
.feature-list li{display:flex;align-items:flex-start;gap:11px;font-size:14.5px;color:var(--text-dim);line-height:1.5}
.feature-list li::before{content:"";flex-shrink:0;width:20px;height:20px;margin-top:1px;border-radius:6px;background:rgba(31,224,122,.14);border:1px solid rgba(31,224,122,.4);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231fe07a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* info panel (sidebar) */
.info-panel{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.info-panel .ip-head{padding:14px 18px;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--cyan);display:flex;align-items:center;gap:8px;background:rgba(20,31,51,.4)}
.info-panel .ip-head::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow)}
.info-panel .ip-row{display:flex;justify-content:space-between;gap:14px;padding:13px 18px;border-bottom:1px solid var(--line-soft);font-size:14px}
.info-panel .ip-row:last-child{border-bottom:none}
.info-panel .ip-row .k{font-family:var(--mono);font-size:11.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--text-mut)}
.info-panel .ip-row .v{color:var(--text);font-weight:600;text-align:right}

.quote-box{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:sticky;top:96px}
.quote-box h3{margin:0 0 16px;font-size:18px;display:flex;align-items:center;gap:8px;font-family:var(--display)}
.quote-box h3::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green-glow)}

/* breadcrumb */
.crumbs{font-family:var(--mono);font-size:12px;color:var(--text-mut);margin-bottom:18px;letter-spacing:.4px}
.crumbs a{color:var(--text-dim)} .crumbs a:hover{color:var(--green)} .crumbs span{color:var(--text-mut);margin:0 8px}

/* filter chips (products) */
.filters{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:18px}
.chip{display:inline-flex;align-items:center;font-family:var(--mono);font-size:12.5px;letter-spacing:.4px;padding:8px 15px;border-radius:999px;border:1px solid var(--line);background:rgba(20,31,51,.4);color:var(--text-dim);transition:.18s var(--ease);cursor:pointer}
.chip:hover{border-color:var(--green);color:var(--text);transform:translateY(-1px)}
.chip.active{background:linear-gradient(135deg,var(--green),var(--green-deep));border-color:transparent;color:#042914;font-weight:600}

/* =========================================================
   FORMS
   ========================================================= */
form.q-form .field{margin-bottom:16px}
form.q-form label > span{display:block;font-family:var(--mono);font-size:11.5px;color:var(--text-dim);letter-spacing:.5px;text-transform:uppercase;margin-bottom:7px}
form.q-form input,form.q-form textarea,form.q-form select{width:100%;padding:13px 15px;background:rgba(20,31,51,.6);border:1px solid var(--line);border-radius:9px;color:var(--text);font:inherit;font-size:15px;transition:.18s var(--ease)}
form.q-form input:focus,form.q-form textarea:focus,form.q-form select:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(31,224,122,.14);background:rgba(20,31,51,.85)}
form.q-form textarea{min-height:120px;resize:vertical}

/* =========================================================
   EMPTY / ALERTS / PROSE
   ========================================================= */
.empty-msg{padding:64px 22px;text-align:center;color:var(--text-mut);border:1px dashed var(--line);border-radius:var(--radius);background:rgba(20,31,51,.25)}
.alert{padding:14px 18px;border-radius:var(--radius-sm);border:1px solid;margin-bottom:22px;font-size:14px}
.alert.ok{background:rgba(31,224,122,.08);border-color:rgba(31,224,122,.35);color:#9be9c2}
.alert.err{background:rgba(255,107,107,.08);border-color:rgba(255,107,107,.35);color:#ffb4b4}
.prose{color:var(--text);font-size:16px;line-height:1.8}
.prose h2{font-size:23px;margin:34px 0 14px;font-family:var(--display);font-weight:700}
.prose h3{font-size:18px;margin:26px 0 10px;font-family:var(--display);font-weight:700}
.prose p{margin:0 0 16px;color:var(--text-dim)}
.prose ul,.prose ol{color:var(--text-dim);padding-left:22px;margin:0 0 16px}
.prose li{margin-bottom:8px}
.prose a{color:var(--cyan);text-decoration:underline}
.prose strong{color:var(--text)}

/* CTA panel */
.cta-panel{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,var(--bg3),var(--panel));padding:clamp(34px,5vw,56px);text-align:center}
.cta-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 220px at 50% -20%,rgba(31,224,122,.14),transparent 70%);pointer-events:none}
.cta-panel h2{font-family:var(--display);font-size:clamp(28px,4.5vw,46px);font-weight:800;margin:0 0 16px;letter-spacing:-.02em}
.cta-panel p{color:var(--text-dim);margin:0 auto 28px;max-width:540px}

/* =========================================================
   WHATSAPP FLOAT
   ========================================================= */
.wa-float{position:fixed;bottom:26px;right:26px;z-index:100;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#25D366,#128C7E);display:grid;place-items:center;color:#fff;font-size:28px;box-shadow:0 16px 34px rgba(37,211,102,0.45);transition:transform .2s var(--ease)}
.wa-float:hover{transform:scale(1.08) rotate(6deg)}
.wa-float::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:2px solid rgba(37,211,102,0.5);animation:ripple 3.2s infinite}

/* =========================================================
   FOOTER
   ========================================================= */
footer.site{border-top:1px solid var(--line);background:linear-gradient(180deg,var(--bg2),var(--bg));padding:64px var(--pad) 30px;margin-top:70px;position:relative}
footer.site::before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,var(--green),var(--cyan),transparent);opacity:.6}
footer.site .grid{max-width:var(--max);margin:0 auto;display:grid;gap:40px;grid-template-columns:2fr 1fr 1fr 1.2fr}
@media (max-width:800px){footer.site .grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){footer.site .grid{grid-template-columns:1fr}}
footer.site h4{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-mut);margin:0 0 16px}
footer.site a{color:var(--text-dim);display:block;padding:5px 0;font-size:14px;transition:.15s var(--ease)}
footer.site a:hover{color:var(--green);transform:translateX(3px)}
footer.site .legal{max-width:var(--max);margin:44px auto 0;border-top:1px solid var(--line);padding-top:22px;font-size:12px;color:var(--text-mut);display:flex;justify-content:space-between;gap:16px;font-family:var(--mono)}
@media (max-width:600px){footer.site .legal{flex-direction:column}}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* =========================================================
   KEYFRAMES
   ========================================================= */
@keyframes pulse{0%,55%,100%{opacity:1}70%,88%{opacity:.4}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes logoSweep{0%,100%{transform:rotate(-46deg)}50%{transform:rotate(46deg)}}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes shimmer{to{background-position:200% center}}
@keyframes ripple{0%{transform:scale(.85);opacity:1}100%{transform:scale(1.45);opacity:0}}

/* SCADA motion */
@keyframes flow{from{stroke-dashoffset:30}to{stroke-dashoffset:0}}
.flow-fast{stroke-dasharray:5 9;animation:flow 4s linear infinite}
.flow-med{stroke-dasharray:5 11;animation:flow 5s linear infinite}
.flow-slow{stroke-dasharray:4 13;animation:flow 6s linear infinite}
@keyframes sweep1{0%,100%{transform:rotate(-22deg)}50%{transform:rotate(28deg)}}
@keyframes sweep2{0%,100%{transform:rotate(18deg)}50%{transform:rotate(48deg)}}
@keyframes sweep3{0%,100%{transform:rotate(-30deg)}50%{transform:rotate(35deg)}}
.needle-1{transform-origin:50px 50px;animation:sweep1 14s ease-in-out infinite}
.needle-2{transform-origin:50px 50px;animation:sweep2 16s ease-in-out infinite}
.needle-3{transform-origin:50px 50px;animation:sweep3 12s ease-in-out infinite}
@keyframes bar{0%,100%{transform:scaleY(.7)}50%{transform:scaleY(1)}}
.bar{transform-origin:bottom}
.bar.a{animation:bar 4.5s ease-in-out infinite}
.bar.b{animation:bar 5s ease-in-out infinite;animation-delay:1s}
.bar.c{animation:bar 5.5s ease-in-out infinite;animation-delay:2s}
.bar.d{animation:bar 6s ease-in-out infinite;animation-delay:.5s}
.valve-rotor{transform-origin:18px 18px;transition:transform .55s cubic-bezier(.6,.05,.4,1)}
.valve-btn.closed .valve-rotor{transform:rotate(90deg)}
.led-slow{animation:pulse 3.5s infinite}
.flame-slow{animation:pulse 2.8s infinite}

@media (max-width:880px){
  .flow-fast,.flow-med,.flow-slow{animation:flow 8s linear infinite}
  .needle-1,.needle-2,.needle-3{animation-duration:20s}
  .bar.a,.bar.b,.bar.c,.bar.d{animation-duration:7s}
}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .reveal{opacity:1 !important;transform:none !important}
  .hero [data-rise],.hero .scada{opacity:1 !important;transform:none !important}
}

/* =========================================================
   COOKIE / PRIVACY NOTICE
   ========================================================= */
.cookie-bar{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:120;
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  max-width:760px;margin:0 auto;
  background:rgba(18,28,46,0.97);backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:14px;
  padding:16px 18px;box-shadow:var(--shadow);
  animation:rise .5s var(--ease) both;
}
.cookie-bar p{margin:0;flex:1;min-width:220px;font-size:13.5px;color:var(--text-dim);line-height:1.6}
.cookie-bar a{color:var(--green);text-decoration:underline}
.cookie-bar .btn{flex-shrink:0}
/* honour the hidden attribute (author display:flex would otherwise override the UA [hidden] rule) */
.cookie-bar[hidden]{display:none}
.legal-links{display:inline-flex;gap:16px;flex-wrap:wrap}
.legal-links a:hover{color:var(--green)}
@media (max-width:520px){.cookie-bar{flex-direction:column;align-items:stretch;text-align:center}.cookie-bar .btn{width:100%}}
