:root{
  --bg:#070B12;--bg-2:#0A101A;--panel:#0E1623;--panel-2:#121E2E;
  --line:rgba(108,142,176,.14);--line-strong:rgba(45,212,232,.30);
  --cyan:#2DD4E8;--cyan-deep:#15A6BE;--amber:#FF8A1E;
  --ink:#EAF1F8;--muted:#8295AC;--muted-2:#5E7186;--ok:#37D399;
  --maxw:1240px;--r:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Saira',system-ui,sans-serif;font-weight:400;line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(108,142,176,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(108,142,176,.04) 1px,transparent 1px);
  background-size:66px 66px;mask-image:radial-gradient(circle at 50% 0%,#000 0%,transparent 82%)}
.glow{position:fixed;border-radius:50%;filter:blur(130px);z-index:0;pointer-events:none}
.glow.a{width:600px;height:600px;background:radial-gradient(circle,rgba(45,212,232,.13),transparent 70%);top:-200px;right:-140px}
.glow.b{width:500px;height:500px;background:radial-gradient(circle,rgba(255,138,30,.07),transparent 70%);top:64vh;left:-180px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}
section{position:relative;z-index:2}
h1,h2,h3{font-family:'Saira',sans-serif;line-height:1.08;letter-spacing:-.02em}
.kicker{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:10px;margin-bottom:18px}
.kicker::before{content:"";width:26px;height:1px;background:var(--cyan);display:inline-block}
.lead{color:var(--muted);font-size:17.5px;max-width:64ch}

.topbar{background:#000;border-bottom:1px solid var(--line);font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;position:relative;z-index:30}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:24px;color:var(--muted);white-space:nowrap;overflow:hidden}
.topbar .wrap>div{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar b{color:var(--cyan);font-weight:600}
.topbar .tb-right{display:flex;gap:20px;align-items:center;flex:0 0 auto}
.topbar .dot{width:6px;height:6px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok);display:inline-block;margin-right:7px;animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@media(max-width:760px){.topbar .tb-hide{display:none}}

nav{position:sticky;top:0;z-index:40;backdrop-filter:blur(14px);background:#000;border-bottom:1px solid var(--line);transition:.3s}
nav.scrolled{background:rgba(8,12,19,.93);border-bottom-color:var(--line-strong)}
nav .wrap{display:flex;align-items:center;justify-content:space-between;height:110px}
.brand{display:flex;align-items:center;gap:13px;text-decoration:none;color:var(--ink)}
.brand .mark{width:40px;height:40px;flex:0 0 40px}
.brand .mark svg{width:100%;height:100%}
.brand .bt{line-height:1}
.brand .bt .n{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:25px;letter-spacing:.16em}
.brand .bt .s{font-family:'IBM Plex Mono',monospace;font-size:9.5px;letter-spacing:.24em;color:var(--muted);text-transform:uppercase}
.navlinks{display:flex;gap:28px;align-items:center}
.navlinks a.lnk{color:var(--muted);text-decoration:none;font-size:14.5px;font-weight:500;transition:.2s;position:relative}
.navlinks a.lnk:hover{color:var(--ink)}
.navlinks a.lnk::after{content:"";position:absolute;left:0;bottom:-7px;height:2px;width:0;background:var(--cyan);transition:.25s}
.navlinks a.lnk:hover::after{width:100%}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Saira',sans-serif;font-weight:600;font-size:14.5px;text-decoration:none;border:none;cursor:pointer;transition:.25s}
.btn-primary{background:var(--cyan);color:#04222a;padding:12px 22px;border-radius:8px;box-shadow:0 0 0 1px rgba(45,212,232,.4),0 8px 30px -8px rgba(45,212,232,.5)}
.btn-primary:hover{background:#43e6f8;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--ink);padding:12px 22px;border-radius:8px;border:1px solid var(--line-strong)}
.btn-ghost:hover{background:rgba(45,212,232,.08);border-color:var(--cyan)}
/* language switch */
.lang{display:inline-flex;border:1px solid var(--line-strong);border-radius:8px;overflow:hidden;font-family:'IBM Plex Mono',monospace}
.lang button{background:transparent;color:var(--muted);border:none;cursor:pointer;font-size:12px;letter-spacing:.08em;padding:9px 13px;font-weight:600;transition:.2s}
.lang button.active{background:var(--cyan);color:#04222a}
.lang button:not(.active):hover{color:var(--ink)}
.menu-toggle{display:none;background:none;border:1px solid var(--line-strong);border-radius:7px;width:44px;height:42px;color:var(--ink);cursor:pointer;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.menu-toggle span{width:20px;height:2px;background:var(--ink)}
@media(max-width:1040px){
  .navlinks{position:fixed;inset:72px 0 auto 0;flex-direction:column;background:#0a101a;border-bottom:1px solid var(--line-strong);padding:24px 28px;gap:20px;align-items:flex-start;transform:translateY(-130%);transition:.35s}
  .navlinks.open{transform:translateY(0)}
  .navlinks .btn,.navlinks .lang{width:100%;justify-content:center}
  .menu-toggle{display:flex}.nav-cta{display:none}
}

.hero{padding:80px 0 72px;position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.12fr .88fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(42px,5.6vw,74px);font-weight:800}
.hero h1 .em{color:transparent;-webkit-text-stroke:1.4px var(--cyan)}
.hero h1 .amb{color:var(--amber)}
.hero .lead{margin:26px 0 34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{display:flex;gap:36px;margin-top:44px;flex-wrap:wrap}
.hero-meta .m .v{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:36px;color:var(--ink);line-height:1}
.hero-meta .m .v span{color:var(--cyan)}
.hero-meta .m .l{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-top:6px;max-width:18ch}

.instrument{position:relative;aspect-ratio:1/1;width:100%;max-width:440px;margin:0 auto}
.instrument .ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--line)}
.instrument .ring.r2{inset:14%}.instrument .ring.r3{inset:30%}.instrument .ring.r4{inset:46%;border-color:var(--line-strong)}
.radar-sweep{position:absolute;inset:0;border-radius:50%;overflow:hidden}
.radar-sweep::before{content:"";position:absolute;inset:0;background:conic-gradient(from 0deg,rgba(45,212,232,.4),transparent 38%);animation:sweep 5s linear infinite}
@keyframes sweep{to{transform:rotate(360deg)}}
.instrument .core{position:absolute;inset:46%;border-radius:50%;background:radial-gradient(circle,rgba(45,212,232,.4),rgba(45,212,232,0))}
.cross{position:absolute;background:var(--line)}
.cross.h{left:0;right:0;top:50%;height:1px}.cross.v{top:0;bottom:0;left:50%;width:1px}
.blip{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 12px var(--amber);transform:translate(-50%,-50%)}
.blip.b1{top:34%;left:62%;animation:blink 5s .6s infinite}
.blip.b2{top:62%;left:40%;animation:blink 5s 2.3s infinite}
.blip.b3{top:48%;left:72%;background:var(--cyan);box-shadow:0 0 12px var(--cyan);animation:blink 5s 3.6s infinite}
@keyframes blink{0%,8%{opacity:1}40%,100%{opacity:.12}}
.gauge-tag{position:absolute;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.1em;color:var(--cyan);background:rgba(8,14,22,.85);border:1px solid var(--line-strong);padding:5px 9px;border-radius:6px;white-space:nowrap}
.gauge-tag.g1{top:6%;left:-4%}
.gauge-tag.g2{bottom:8%;right:-2%;color:var(--amber);border-color:rgba(255,138,30,.4)}
.gauge-tag.g3{top:50%;right:-6%;transform:translateY(-50%)}
@media(max-width:1040px){.hero .wrap{grid-template-columns:1fr;gap:44px}.instrument{max-width:330px}.gauge-tag{display:none}}

.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2);padding:26px 0}
.trust .wrap{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:space-between}
.trust .lab{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);white-space:nowrap}
.classes{display:flex;gap:28px;flex-wrap:wrap;align-items:center}
.classes span{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:21px;letter-spacing:.06em;color:var(--muted);transition:.2s}
.classes span:hover{color:var(--cyan)}

.shead{max-width:780px;margin-bottom:54px}
.shead h2{font-size:clamp(28px,3.4vw,44px);font-weight:700}
.shead p{color:var(--muted);margin-top:16px;font-size:17px}
.sec-pad{padding:96px 0}

/* partner / kobelt feature */
.partner{background:linear-gradient(180deg,var(--bg),var(--bg-2));border-top:1px solid var(--line)}
.partner .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:58px;align-items:center}
.partner h2{font-size:clamp(28px,3.4vw,44px);font-weight:700}
.partner .lead{margin-top:18px}
.kobelt-quote{margin-top:26px;border-left:2px solid var(--cyan);padding:6px 0 6px 22px;color:var(--ink);font-size:18px;font-weight:500;font-style:italic}
.kvals{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.kval{background:var(--panel);padding:26px 24px}
.kval .ic{width:42px;height:42px;border-radius:10px;border:1px solid var(--line-strong);background:rgba(45,212,232,.06);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.kval .ic svg{width:21px;height:21px;stroke:var(--cyan)}
.kval h4{font-size:17px;font-weight:600;margin-bottom:6px}
.kval p{color:var(--muted);font-size:13.5px;line-height:1.55}
@media(max-width:1040px){.partner .wrap{grid-template-columns:1fr;gap:40px}}

/* why-partner pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.pillar{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;position:relative;overflow:hidden;transition:.3s}
.pillar:hover{border-color:var(--line-strong);transform:translateY(-5px)}
.pillar::before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--cyan),transparent);transform:scaleX(0);transform-origin:left;transition:.4s}
.pillar:hover::before{transform:scaleX(1)}
.pillar .ic{width:50px;height:50px;border-radius:12px;border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;margin-bottom:22px;background:rgba(45,212,232,.06)}
.pillar .ic svg{width:25px;height:25px;stroke:var(--cyan)}
.pillar h3{font-size:21px;font-weight:700;margin-bottom:10px}
.pillar p{color:var(--muted);font-size:15px}
.pillar.feat{background:linear-gradient(160deg,rgba(45,212,232,.09),var(--bg-2));border-color:var(--line-strong)}
@media(max-width:920px){.pillars{grid-template-columns:1fr}}

.prod-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.prods{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.pcard{background:var(--panel);padding:30px 26px 28px;position:relative;transition:.28s;min-height:220px;display:flex;flex-direction:column}
.pcard:hover{background:var(--panel-2)}
.pcard .num{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted-2);letter-spacing:.12em}
.pcard .pic{width:44px;height:44px;margin:14px 0 18px;color:var(--cyan)}
.pcard:hover .pic{color:var(--amber)}
.pcard .pic svg{width:100%;height:100%;stroke:currentColor;transition:.28s}
.pcard h3{font-size:18px;font-weight:600;margin-bottom:6px}
.pcard p{color:var(--muted);font-size:13.5px;line-height:1.5}
@media(max-width:1040px){.prods{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.prods{grid-template-columns:1fr}}

.eng{background:linear-gradient(180deg,var(--bg-2),var(--bg));border-top:1px solid var(--line)}
.eng .wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center}
.eng-panel{background:#06090f;border:1px solid var(--line-strong);border-radius:16px;overflow:hidden;box-shadow:0 40px 80px -40px rgba(0,0,0,.8)}
.eng-bar{background:#0b1320;border-bottom:1px solid var(--line);padding:12px 18px;display:flex;align-items:center;gap:10px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.eng-bar .led{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.eng-bar .led.am{background:var(--amber);box-shadow:0 0 8px var(--amber)}
.eng-screen{padding:26px 24px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.read{background:#0a121e;border:1px solid var(--line);border-radius:10px;padding:16px}
.read .rl{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.read .rv{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:33px;color:var(--cyan);line-height:1;margin-top:6px}
.read .rv.am{color:var(--amber)}
.read .ru{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);margin-left:5px}
.read.full{grid-column:1/3}
.bar-track{height:10px;border-radius:5px;background:#0d1626;overflow:hidden;margin-top:12px;border:1px solid var(--line)}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--cyan-deep),var(--cyan));border-radius:5px;width:72%;box-shadow:0 0 12px rgba(45,212,232,.6)}
.eng-list{list-style:none;margin-top:26px;display:grid;gap:14px}
.eng-list li{display:flex;gap:14px;align-items:flex-start;color:var(--muted);font-size:15.5px}
.eng-list li b{color:var(--ink);font-weight:600}
.eng-list .ck{flex:0 0 22px;width:22px;height:22px;border-radius:6px;background:rgba(45,212,232,.1);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;margin-top:2px}
.eng-list .ck svg{width:13px;height:13px;stroke:var(--cyan)}
@media(max-width:1040px){.eng .wrap{grid-template-columns:1fr;gap:40px}}

.region{background:linear-gradient(160deg,#0b1422,#080d16);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.region .wrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:center}
.region h2{font-size:clamp(28px,3.4vw,44px);font-weight:700}
.region .lead{margin-top:18px}
.region .hub{display:inline-flex;align-items:center;gap:10px;margin-top:24px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);border:1px solid rgba(255,138,30,.35);padding:9px 14px;border-radius:30px}
.region .hub .pin{width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 10px var(--amber)}
.region-map{position:relative;border:1px solid var(--line-strong);border-radius:16px;background:#06090f;padding:30px 28px;box-shadow:0 40px 80px -40px rgba(0,0,0,.8)}
.region-map .rm-head{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:22px;display:flex;align-items:center;gap:9px}
.region-map .rm-head .d{width:7px;height:7px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.region-tags{display:flex;flex-wrap:wrap;gap:10px}
.region-tags .c{display:inline-flex;align-items:center;gap:8px;font-size:14px;color:var(--muted);background:#0b1320;border:1px solid var(--line);padding:9px 14px;border-radius:9px;transition:.22s}
.region-tags .c::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cyan-deep);opacity:.7}
.region-tags .c:hover{color:var(--ink);border-color:var(--line-strong);transform:translateY(-2px)}
.region-tags .c.hubcity{color:#04222a;background:var(--cyan);border-color:var(--cyan);font-weight:700}
.region-tags .c.hubcity::before{background:#04222a;opacity:1}
@media(max-width:1040px){.region .wrap{grid-template-columns:1fr;gap:40px}}

.inds{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ind{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;min-height:220px;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;transition:.3s;background:linear-gradient(180deg,var(--panel),var(--bg-2))}
.ind:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.ind .bgnum{position:absolute;top:8px;right:18px;font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:86px;color:rgba(108,142,176,.06);line-height:1}
.ind h3{font-size:20px;font-weight:700;position:relative}
.ind p{color:var(--muted);font-size:14px;margin-top:8px;position:relative}
.ind .pill{position:absolute;top:22px;left:26px;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);border:1px solid var(--line-strong);padding:4px 9px;border-radius:20px}
@media(max-width:920px){.inds{grid-template-columns:1fr}}

.statsband{background:linear-gradient(120deg,#0b1320,#0a0f18);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.statsband .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.stat{background:var(--bg);padding:46px 30px;text-align:center}
.stat .v{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:54px;line-height:1;color:var(--ink)}
.stat .v span{color:var(--cyan)}
.stat .l{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);margin-top:12px}
@media(max-width:920px){.statsband .wrap{grid-template-columns:1fr 1fr}}

.cta{padding:100px 0}
.cta .box{background:linear-gradient(150deg,var(--panel-2),var(--bg-2));border:1px solid var(--line-strong);border-radius:20px;padding:60px;position:relative;overflow:hidden}
.cta .box::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(45,212,232,.14),transparent 70%);top:-120px;right:-80px}
.cta .grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:center;position:relative;z-index:2}
.cta h2{font-size:clamp(28px,3.4vw,42px);font-weight:700}
.cta p{color:var(--muted);margin-top:16px;font-size:17px}
.contact-card{background:#070b12;border:1px solid var(--line);border-radius:14px;padding:28px}
.contact-card .row{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line);align-items:center}
.contact-card .row:last-child{border-bottom:none}
.contact-card .ic{width:38px;height:38px;border-radius:9px;background:rgba(45,212,232,.08);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;flex:0 0 38px}
.contact-card .ic svg{width:18px;height:18px;stroke:var(--cyan)}
.contact-card .rl{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
.contact-card .rv{color:var(--ink);font-size:15px;font-weight:500}
.cta-actions{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
@media(max-width:920px){.cta .box{padding:36px 26px}.cta .grid{grid-template-columns:1fr;gap:34px}}

footer{border-top:1px solid var(--line);background:var(--bg-2);padding:64px 0 30px}
.fgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.fcol h4{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:18px}
.fcol a{display:block;color:var(--muted);text-decoration:none;font-size:14.5px;margin-bottom:11px;transition:.2s}
.fcol a:hover{color:var(--cyan)}
.fcol p{color:var(--muted);font-size:14px;max-width:38ch}
.foot-brand .n{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:26px;letter-spacing:.16em}
.fbot{border-top:1px solid var(--line);margin-top:50px;padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.06em;color:var(--muted-2)}
@media(max-width:920px){.fgrid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.fgrid{grid-template-columns:1fr}}

/* ---- sub-pages (detail / catalogue) ---- */
#page-detail,#page-catalogue{display:none}
.subhero{padding:54px 0 10px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.crumb{display:flex;align-items:center;gap:10px;font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:22px}
.crumb a{color:var(--cyan);text-decoration:none;cursor:pointer}
.crumb a:hover{text-decoration:underline}
.subhero h1{font-size:clamp(34px,4.6vw,56px);font-weight:800;max-width:18ch}
.subhero .tl{color:var(--muted);font-size:18px;margin-top:16px;max-width:60ch}
.subhero .num-badge{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.18em;color:var(--amber);text-transform:uppercase;margin-bottom:14px;display:block}
.detail-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;padding-top:60px;align-items:start}
.detail-grid h2{font-size:26px;font-weight:700;margin:0 0 18px}
.detail-grid h2:not(:first-child){margin-top:42px}
.detail-grid p{color:var(--muted);font-size:16px;margin-bottom:14px}
.feat-list{list-style:none;display:grid;gap:13px;margin-top:6px}
.feat-list li{display:flex;gap:13px;align-items:flex-start;color:var(--muted);font-size:15.5px}
.feat-list .ck{flex:0 0 22px;width:22px;height:22px;border-radius:6px;background:rgba(45,212,232,.1);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;margin-top:2px}
.feat-list .ck svg{width:13px;height:13px;stroke:var(--cyan)}
.app-tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:6px}
.app-tags span{font-size:13.5px;color:var(--muted);background:#0b1320;border:1px solid var(--line);padding:7px 13px;border-radius:8px}
.detail-side{position:sticky;top:96px;display:grid;gap:20px}
.side-card{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line-strong);border-radius:14px;padding:26px}
.side-card .picbig{width:60px;height:60px;color:var(--cyan);margin-bottom:18px}
.side-card .picbig svg{width:100%;height:100%;stroke:currentColor}
.side-card h4{font-size:13px;font-family:'IBM Plex Mono',monospace;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:14px}
.spec-row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px}
.spec-row:last-child{border-bottom:none}
.spec-row .k{color:var(--muted)}.spec-row .v{color:var(--ink);font-weight:500;text-align:right}
.side-cta{background:linear-gradient(150deg,rgba(45,212,232,.12),var(--bg-2));border:1px solid var(--line-strong);border-radius:14px;padding:24px;text-align:center}
.side-cta p{color:var(--muted);font-size:14px;margin-bottom:16px}
.related{border-top:1px solid var(--line);margin-top:10px}
.rel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.rel-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px;cursor:pointer;transition:.25s}
.rel-card:hover{border-color:var(--line-strong);transform:translateY(-3px);background:var(--panel-2)}
.rel-card .rn{font-family:'IBM Plex Mono',monospace;font-size:10.5px;color:var(--muted-2);letter-spacing:.12em}
.rel-card h4{font-size:15px;font-weight:600;margin-top:8px}
.pcard{cursor:pointer}
.pcard .arr{position:absolute;right:22px;top:26px;color:var(--muted-2);transition:.25s;opacity:0;transform:translateX(-6px)}
.pcard:hover .arr{opacity:1;transform:translateX(0);color:var(--cyan)}
@media(max-width:1040px){.detail-grid{grid-template-columns:1fr;gap:36px}.detail-side{position:static}.rel-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.rel-grid{grid-template-columns:1fr}}

.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* language visibility */
[data-tr]{display:none}
html[lang="tr"] [data-en]{display:none}
html[lang="tr"] [data-tr]{display:initial}

/* ===== multi-page additions ===== */
.navlinks a.lnk.active{color:var(--ink)}
.navlinks a.lnk.active::after{width:100%}
/* sub-pages are normal flow now (no JS show/hide) */
#page-detail,#page-catalogue{display:block}
.content{padding:70px 0 90px}
.content .wrap{max-width:920px}
.content h2{font-size:28px;font-weight:700;margin:42px 0 16px}
.content h2:first-child{margin-top:0}
.content h3{font-size:20px;font-weight:600;margin:28px 0 10px}
.content p{color:var(--muted);font-size:16.5px;margin-bottom:16px}
.content ul{list-style:none;display:grid;gap:12px;margin:6px 0 18px}
.content ul li{display:flex;gap:13px;align-items:flex-start;color:var(--muted);font-size:16px}
.content ul li .ck{flex:0 0 22px;width:22px;height:22px;border-radius:6px;background:rgba(45,212,232,.1);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;margin-top:3px}
.content ul li .ck svg{width:13px;height:13px;stroke:var(--cyan)}
.content .big{font-size:19px;color:var(--ink);font-weight:500;border-left:2px solid var(--cyan);padding-left:20px;margin:24px 0}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin:20px 0}
.infocard{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:14px;padding:28px}
.infocard .ic{width:46px;height:46px;border-radius:11px;border:1px solid var(--line-strong);background:rgba(45,212,232,.06);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.infocard .ic svg{width:23px;height:23px;stroke:var(--cyan)}
.infocard h3{margin:0 0 8px;font-size:18px}
.infocard p{font-size:14.5px;margin:0}
@media(max-width:720px){.twocol{grid-template-columns:1fr}}
.ind{cursor:pointer}
.timeline{display:grid;gap:0;margin:24px 0}
.tl-item{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:22px 0;border-bottom:1px solid var(--line)}
.tl-item:last-child{border-bottom:none}
.tl-item .yr{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:30px;color:var(--cyan);line-height:1}
.tl-item .tx h3{margin:0 0 6px;font-size:18px}
.tl-item .tx p{margin:0;font-size:15px}
@media(max-width:640px){.tl-item{grid-template-columns:1fr;gap:8px}}

/* ===== ocean theme — home colour & imagery ===== */
:root{
  --ocean-deep:#041726;
  --ocean-mid:#073a52;
  --teal:#19C6C6;
  --aqua:#36E0D0;
}
/* richer body gradient wash */
body{background:
  radial-gradient(1200px 600px at 80% -10%, rgba(25,198,198,.10), transparent 60%),
  radial-gradient(900px 500px at 0% 30%, rgba(20,80,120,.16), transparent 60%),
  linear-gradient(180deg,#05101c 0%, #070B12 40%);
}
/* hero gets a deep-sea gradient panel */
.hero{background:
  radial-gradient(700px 360px at 75% 20%, rgba(54,224,208,.10), transparent 70%),
  linear-gradient(160deg, rgba(7,58,82,.55), rgba(7,11,18,0) 60%);
}
.hero h1 .amb{color:var(--amber)}
.hero h1 .em{-webkit-text-stroke:1.4px var(--aqua)}
/* animated wave divider */
.wave{display:block;width:100%;height:70px;margin:0;line-height:0}
.wave svg{width:100%;height:100%;display:block}
.wave path{fill:rgba(25,198,198,.06)}
.wave.flip{transform:rotate(180deg)}
/* trust strip — teal tint */
.trust{background:linear-gradient(90deg, rgba(7,58,82,.5), rgba(10,16,26,.5))}
/* partner section ocean wash */
.partner{background:
  radial-gradient(600px 300px at 10% 20%, rgba(25,198,198,.08), transparent 70%),
  linear-gradient(180deg,#06121f,#0A101A)}
.kval{background:linear-gradient(160deg, rgba(13,40,58,.6), var(--bg-2))}
.kval .ic{background:linear-gradient(135deg, rgba(54,224,208,.14), rgba(25,198,198,.04));border-color:rgba(54,224,208,.4)}
.kval .ic svg{stroke:var(--aqua)}
/* product cards — colourful image area */
.pcard{overflow:hidden}
.pcard .media{margin:-30px -26px 16px;height:128px;position:relative;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0a2a3c,#0d3a4f 55%,#08263a);overflow:hidden;border-bottom:1px solid var(--line-strong)}
.pcard .media::after{content:"";position:absolute;inset:0;background:
  radial-gradient(120px 80px at 70% 30%, rgba(54,224,208,.22), transparent 70%);}
.pcard .media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;z-index:2}
.pcard .media .ph{position:relative;z-index:1;width:54px;height:54px;opacity:.9}
.pcard .media .ph svg{width:100%;height:100%;stroke:var(--aqua);filter:drop-shadow(0 0 10px rgba(54,224,208,.4))}
.pcard:hover .media{background:linear-gradient(135deg,#0c3b52,#0f4660 55%,#0a2e44)}
.pcard:hover .media .ph svg{stroke:#7af3e8}
.pcard .num{color:var(--teal)}
/* hero instrument — warmer glow */
.instrument .core{background:radial-gradient(circle, rgba(54,224,208,.5), transparent)}
.radar-sweep::before{background:conic-gradient(from 0deg, rgba(54,224,208,.5), transparent 38%)}
.blip.b3{background:var(--aqua);box-shadow:0 0 12px var(--aqua)}
/* eng panel ocean tint */
.eng{background:linear-gradient(180deg,#06121f,#070B12)}
/* stat band */
.statsband{background:linear-gradient(120deg,#06222f,#081420)}
.stat .v span{color:var(--aqua)}
/* cta box ocean */
.cta .box{background:linear-gradient(150deg, rgba(13,58,79,.7), var(--bg-2));border-color:rgba(54,224,208,.35)}
.cta .box::after{background:radial-gradient(circle, rgba(54,224,208,.20), transparent 70%)}
/* section kicker accent */
.kicker{color:var(--aqua)}
.kicker::before{background:var(--aqua)}
/* hero meta accent */
.hero-meta .m .v span{color:var(--aqua)}
/* media hero band behind instrument */
.hero .instrument::after{content:"";position:absolute;inset:-12%;border-radius:50%;
  background:radial-gradient(circle, rgba(25,198,198,.10), transparent 65%);z-index:-1}

/* system detail banner image (optional upload) */
.sysbanner{margin-top:28px;border-radius:14px;overflow:hidden;border:1px solid var(--line-strong);max-height:320px}
.sysbanner img{width:100%;display:block;object-fit:cover;max-height:320px}

/* full-bleed SVG art inside card media; photo (if uploaded) sits on top */
.pcard .media .art{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.pcard .media img{z-index:3}
.pcard .media::after{z-index:2}

/* system banner: SVG art fills, photo overrides on top */
.sysbanner{position:relative;min-height:200px;background:#08263a}
.sysbanner .art{position:absolute;inset:0;width:100%;height:100%}
.sysbanner img{position:relative;z-index:2}

/* class compliance strip on system detail pages */
.class-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:4px}
.class-strip span{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:18px;letter-spacing:.05em;color:var(--cyan);background:rgba(45,212,232,.07);border:1px solid var(--line-strong);padding:8px 16px;border-radius:8px}
.class-note{color:var(--muted);font-size:13.5px;margin-top:14px}

/* ===== HMI monitoring panel (small, right column, uses real image) ===== */
.hmi-frame{border:1px solid var(--line-strong);border-radius:16px;overflow:hidden;background:#06121d;box-shadow:0 40px 80px -45px rgba(0,0,0,.8)}
.hmi-bar{background:#0b1320;border-bottom:1px solid var(--line);padding:12px 18px;display:flex;align-items:center;gap:10px;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.hmi-bar .led{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 8px var(--ok)}
.hmi-bar .led.am{background:var(--amber);box-shadow:0 0 8px var(--amber)}
.hmi-stage{position:relative;min-height:200px;background:#06141d;display:flex}
.hmi-stage img{width:100%;height:auto;display:block;position:relative;z-index:2}
.hmi-ph{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px;
  color:var(--muted-2);font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  background:repeating-linear-gradient(135deg,#0a1a26,#0a1a26 14px,#0c2030 14px,#0c2030 28px)}

/* ===== HMI slideshow (auto-cycling) ===== */
.hmi-slides{position:relative;overflow:hidden;background:#06141d}
.hmi-slides img{position:absolute;top:0;left:0;width:100%;height:auto;display:block;opacity:0;transition:opacity .35s ease;z-index:2}
.hmi-slides img:first-of-type{position:relative}  /* first defines the box height */
.hmi-slides img.on{opacity:1;z-index:3}
.hmi-dots{position:absolute;left:0;right:0;bottom:10px;z-index:5;display:flex;gap:7px;justify-content:center}
.hmi-dots i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.25);transition:.25s;cursor:pointer}
.hmi-dots i.on{background:var(--cyan);box-shadow:0 0 8px var(--cyan);width:18px;border-radius:4px}

/* ===== contact page extras ===== */
.dept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.dept{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:16px;padding:28px;transition:.3s}
.dept:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.dept .i{width:50px;height:50px;border-radius:13px;background:rgba(45,212,232,.07);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.dept .i svg{width:25px;height:25px;stroke:var(--cyan)}
.dept h3{font-size:19px;font-weight:700;margin-bottom:4px}
.dept .sub{color:var(--muted);font-size:13.5px;margin-bottom:18px}
.dept .num{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:24px;color:var(--ink);letter-spacing:.02em}
.dept .num a{color:var(--ink);text-decoration:none}
.dept .num a:hover{color:var(--cyan)}
.dept .acts{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.btn-wa{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#04331a;font-family:'Saira',sans-serif;font-weight:700;font-size:14px;text-decoration:none;padding:11px 18px;border-radius:9px;transition:.25s}
.btn-wa:hover{background:#3ee87c;transform:translateY(-2px)}
.btn-wa svg{width:18px;height:18px;fill:#04331a}
.btn-call{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--line-strong);color:var(--ink);font-family:'Saira',sans-serif;font-weight:600;font-size:14px;text-decoration:none;padding:11px 16px;border-radius:9px;transition:.25s}
.btn-call:hover{border-color:var(--cyan);color:var(--cyan)}
@media(max-width:880px){.dept-grid{grid-template-columns:1fr}}

/* map + location */
.loc-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:24px;margin-top:8px}
.map-card{position:relative;border:1px solid var(--line-strong);border-radius:16px;overflow:hidden;min-height:300px;background:#06141d;text-decoration:none;display:block}
.map-card .mv{position:absolute;inset:0;width:100%;height:100%}
.map-card img.realmap{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.map-pin{position:absolute;left:50%;top:46%;transform:translate(-50%,-100%);z-index:4}
.map-pin svg{width:40px;height:40px;filter:drop-shadow(0 6px 12px rgba(0,0,0,.5))}
.map-pulse{position:absolute;left:50%;top:46%;width:22px;height:22px;border-radius:50%;background:rgba(255,138,30,.5);transform:translate(-50%,-50%);z-index:3;animation:mp 2.2s infinite}
@keyframes mp{0%{box-shadow:0 0 0 0 rgba(255,138,30,.5)}100%{box-shadow:0 0 0 26px rgba(255,138,30,0)}}
.map-badge{position:absolute;left:18px;top:16px;z-index:5;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);background:rgba(6,18,28,.8);border:1px solid var(--line-strong);padding:7px 12px;border-radius:8px}
.map-open{position:absolute;right:18px;bottom:16px;z-index:5;display:inline-flex;align-items:center;gap:8px;background:var(--cyan);color:#04222a;font-family:'Saira';font-weight:700;font-size:14px;padding:11px 18px;border-radius:30px;text-decoration:none;transition:.25s}
.map-card:hover .map-open{background:#43e6f8}
.loc-info{background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:16px}
.loc-row{display:flex;gap:13px;align-items:flex-start}
.loc-row .ic{width:38px;height:38px;border-radius:10px;background:rgba(45,212,232,.07);border:1px solid var(--line-strong);display:flex;align-items:center;justify-content:center;flex:0 0 38px}
.loc-row .ic svg{width:18px;height:18px;stroke:var(--cyan)}
.loc-row .rl{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2)}
.loc-row .rv{color:var(--ink);font-size:15px;font-weight:500}
.loc-row .rv.coord{font-family:'IBM Plex Mono',monospace;font-size:15px;color:var(--cyan);letter-spacing:.02em}
@media(max-width:880px){.loc-grid{grid-template-columns:1fr}}

/* downloads */
.dl-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:8px}
.dl-card{display:flex;gap:20px;align-items:center;background:linear-gradient(160deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:16px;padding:22px;text-decoration:none;transition:.3s}
.dl-card:hover{border-color:var(--line-strong);transform:translateY(-4px)}
.dl-cover{flex:0 0 92px;width:92px;height:120px;border-radius:10px;overflow:hidden;position:relative;border:1px solid var(--line-strong);background:linear-gradient(160deg,#0a2a3c,#0d3a4f)}
.dl-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.dl-cover .ph{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center}
.dl-cover .ph svg{width:34px;height:34px;stroke:var(--aqua)}
.dl-meta .k{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:6px}
.dl-meta h3{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:6px}
.dl-meta p{color:var(--muted);font-size:13.5px;margin-bottom:10px}
.dl-meta .go{display:inline-flex;align-items:center;gap:7px;font-family:'Saira';font-weight:700;font-size:14px;color:var(--cyan)}
@media(max-width:880px){.dl-grid{grid-template-columns:1fr}}

/* ===== brand logo image — no frame, sits directly on nav ===== */
.brand{background:none;border-radius:0;padding:0;box-shadow:none}
.brand-logo{height:96px;width:auto;display:block;max-width:380px;object-fit:contain}
.foot-brand .brand{display:inline-flex;background:none;border-radius:0;padding:0}
.foot-logo{height:108px;max-width:340px;filter:none;mix-blend-mode:lighten}
@media(max-width:1040px){.brand-logo{height:70px;max-width:260px}}

/* ===== PDF document cards (prominent, downloadable) ===== */
.doc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:10px}
.doc-grid.cols3{grid-template-columns:repeat(3,1fr)}
.doc-card{display:flex;flex-direction:column;background:linear-gradient(165deg,var(--panel),var(--bg-2));border:1px solid var(--line);border-radius:14px;overflow:hidden;text-decoration:none;transition:.28s;position:relative}
.doc-card:hover{transform:translateY(-6px);border-color:var(--cyan);box-shadow:0 24px 50px -28px rgba(45,212,232,.4)}
.doc-thumb{position:relative;height:150px;background:#fff;display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--line-strong)}
.doc-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:2}
.doc-thumb .pdfmark{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px;color:#c2402e}
.doc-thumb .pdfmark svg{width:46px;height:46px}
.doc-thumb .pdfmark span{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:15px;letter-spacing:.12em;color:#9aa6ad}
.doc-thumb::after{content:"";position:absolute;left:0;right:0;bottom:0;height:42px;z-index:3;background:linear-gradient(180deg,transparent,rgba(6,18,28,.0))}
.doc-badge{position:absolute;top:10px;left:10px;z-index:4;font-family:'IBM Plex Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;background:rgba(6,18,28,.82);color:var(--cyan);border:1px solid var(--line-strong);padding:4px 9px;border-radius:20px}
.doc-body{padding:15px 16px 17px;display:flex;flex-direction:column;gap:4px;flex:1}
.doc-body h4{font-size:14.5px;font-weight:700;line-height:1.3;color:var(--ink)}
.doc-dl{margin-top:auto;display:inline-flex;align-items:center;gap:7px;font-family:'Saira',sans-serif;font-weight:700;font-size:13px;color:var(--cyan);padding-top:10px}
.doc-dl svg{width:15px;height:15px;stroke:var(--cyan)}
.doc-card:hover .doc-dl{color:#43e6f8}
@media(max-width:1040px){.doc-grid,.doc-grid.cols3{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.doc-grid,.doc-grid.cols3{grid-template-columns:1fr}}

/* compact doc list for system detail sidebar/section */
.doc-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.doc-row{display:flex;align-items:center;gap:13px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:12px 14px;text-decoration:none;transition:.25s}
.doc-row:hover{border-color:var(--cyan);transform:translateX(4px)}
.doc-row .di{flex:0 0 34px;width:34px;height:42px;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.doc-row .di img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.doc-row .di svg{width:18px;height:18px;color:#c2402e}
.doc-row .dn{flex:1;font-size:14px;font-weight:600;color:var(--ink);line-height:1.25}
.doc-row .da{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-family:'Saira';font-weight:700;font-size:12.5px;color:var(--cyan)}
.doc-row .da svg{width:14px;height:14px;stroke:var(--cyan)}

/* ============ MOBILE POLISH (<=560px) ============ */
@media(max-width:560px){
  .wrap{padding-left:18px;padding-right:18px}
  /* topbar: keep one tidy line, hide the long left text, show phone */
  .topbar .wrap{height:34px;gap:10px}
  .topbar{font-size:9.5px;letter-spacing:.04em}
  .topbar .tb-left{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  /* nav + logo */
  nav .wrap{height:74px}
  .brand-logo{height:50px;max-width:190px}
  .menu-toggle{flex:0 0 auto}
  /* headings scale down */
  .hero h1{font-size:34px;line-height:1.06}
  .hero .lead,.hero p.lead{font-size:15.5px}
  h2{font-size:26px !important;line-height:1.12}
  .subhero h1{font-size:30px}
  .sec-pad{padding-top:54px;padding-bottom:54px}
  section{overflow-x:hidden}
  /* buttons full width-ish, wrap nicely */
  .hero .btn,.hero a.btn{flex:1 1 auto;justify-content:center;text-align:center}
  /* stats: 2 cols stays, tighten */
  .statsband .wrap{gap:24px 16px;padding:40px 18px}
  .stat .v{font-size:40px}
  /* HMI slideshow fits within card */
  .hmi-stage{padding:8px}
  .hmi-bar{font-size:9.5px;padding:9px 12px;letter-spacing:.06em}
  /* doc cards single column, comfortable */
  .doc-thumb{height:130px}
  /* prevent any wide element from causing horizontal scroll */
  img,svg,.hmi-frame,.map-card{max-width:100%}
  /* contact dept / map / forms already 1-col via their own queries */
  .cta .box,.cta{padding-left:18px;padding-right:18px}
  /* footer tidy */
  .foot-logo{height:78px;max-width:220px}
  .fbot{flex-direction:column;gap:8px;font-size:10px}
}
/* mid phones / large phones */
@media(max-width:760px){
  .topbar .tb-left{max-width:60vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}
  .hero h1{font-size:clamp(30px,8vw,46px)}
}
/* guard against horizontal overflow site-wide */
html,body{max-width:100%;overflow-x:hidden}
