:root{--navy:#031d35;--navy2:#062d52;--gold:#f6b800;--white:#fff;--muted:#65758b;--line:#dbe3ec;--bg:#f6f8fb;--shadow:0 24px 70px rgba(3,29,53,.14);--radius:28px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--navy);background:var(--white);line-height:1.55}.container{width:min(1160px,92%);margin:auto}.site-header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.84);backdrop-filter:blur(18px);border-bottom:1px solid rgba(219,227,236,.8)}.nav{height:78px;display:flex;align-items:center;justify-content:space-between}.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--navy);font-weight:800;letter-spacing:.04em;text-transform:uppercase}.brand-logo{width:54px;height:42px;object-fit:contain;display:block}.brand-text{font-size:18px}.nav-links{display:flex;gap:28px;align-items:center}.nav-links a{text-decoration:none;color:var(--navy);font-weight:650;font-size:14px}.nav-cta{padding:12px 18px;border-radius:999px;background:var(--navy)!important;color:#fff!important}.nav-toggle{display:none;border:0;background:var(--navy);color:#fff;border-radius:12px;padding:10px 12px}.section-pad{padding:96px 0}.hero{overflow:hidden;background:radial-gradient(circle at 85% 10%,rgba(246,184,0,.20),transparent 34%),linear-gradient(180deg,#fff 0%,#f6f8fb 100%)}.hero-grid,.split-grid,.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:800;color:var(--gold);margin:0 0 14px}h1,h2,h3,p{margin-top:0}h1{font-size:clamp(46px,7vw,84px);line-height:.96;letter-spacing:-.06em;margin-bottom:24px}h2{font-size:clamp(34px,4vw,56px);line-height:1;letter-spacing:-.045em;margin-bottom:18px}.lead{font-size:20px;color:var(--muted);max-width:620px}.lead.small{font-size:18px}.hero-actions{display:flex;gap:14px;margin:34px 0}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:15px 24px;font-weight:800;text-decoration:none;cursor:pointer}.btn-primary{background:var(--gold);color:var(--navy);box-shadow:0 14px 34px rgba(246,184,0,.28)}.btn-secondary{background:#fff;color:var(--navy);border:1px solid var(--line)}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:520px}.stats div{padding:18px;background:#fff;border:1px solid var(--line);border-radius:18px}.stats strong{display:block;font-size:24px}.stats span{color:var(--muted);font-size:13px}.hero-image-wrap{min-height:560px;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;background:#eef2f6;position:relative}.hero-image-wrap:after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);border-radius:inherit;pointer-events:none}.hero-lockers-img{width:100%;height:560px;display:block;object-fit:cover;object-position:center center}.hero-visual{position:relative}
.image-placeholder{min-height:430px;border-radius:var(--radius);background:linear-gradient(135deg,#0b2238,#123f65);box-shadow:var(--shadow);display:grid;place-items:center;position:relative;overflow:hidden}.image-placeholder:before{content:"";position:absolute;inset:22px;border:1px dashed rgba(255,255,255,.35);border-radius:22px}.image-placeholder:after{content:"";position:absolute;width:170px;height:120%;background:var(--gold);transform:rotate(18deg);right:12%;opacity:.9}.image-placeholder span{z-index:2;color:#fff;font-weight:800;background:rgba(3,29,53,.55);padding:14px 18px;border-radius:999px}.floating-card{position:absolute;right:-20px;bottom:34px;background:#fff;border-radius:22px;padding:20px 22px;box-shadow:var(--shadow);font-weight:800}.floating-card small{color:var(--muted);font-weight:600}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#2bd673;margin-right:8px}.light{background:var(--bg)}.section-head{max-width:720px;margin-bottom:36px}.section-head p:not(.eyebrow){color:var(--muted);font-size:18px}.cards{display:grid;gap:22px}.three{grid-template-columns:repeat(3,1fr)}.four{grid-template-columns:repeat(4,1fr)}.card,.location-card,.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:0 12px 40px rgba(3,29,53,.06)}.card .icon{width:54px;height:54px;border-radius:18px;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:900;margin-bottom:22px}.card p{color:var(--muted)}.tall-placeholder{min-height:560px}.timeline{display:grid;gap:18px;margin-top:28px}.timeline div{display:grid;grid-template-columns:48px 1fr;gap:0 18px;padding:20px;border:1px solid var(--line);border-radius:22px}.timeline b{grid-row:span 2;width:48px;height:48px;background:var(--gold);border-radius:16px;display:grid;place-items:center}.timeline p{color:var(--muted);margin:0}.navy{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff}.navy .section-head p:not(.eyebrow){color:#b9c7d8}.gold{color:var(--gold)}.location-card{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);box-shadow:none;color:#fff}.location-card p{color:#b9c7d8}.project-card{min-height:260px}.project-tag{display:inline-flex;margin-bottom:16px;padding:8px 12px;border-radius:999px;background:rgba(246,184,0,.16);color:var(--gold);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.project-card h3{line-height:1.12}.project-card p{font-size:15px}
.contact-list{display:grid;gap:14px;margin-top:28px}.contact-list a{color:var(--navy);font-weight:800;text-decoration:none;padding:18px 20px;background:var(--bg);border-radius:18px}.contact-form{display:grid;gap:16px}.contact-form label{font-weight:750}.contact-form input,.contact-form textarea{width:100%;margin-top:8px;border:1px solid var(--line);border-radius:16px;padding:15px 16px;font:inherit}.footer{background:var(--navy);color:#fff;padding:28px 0}.footer-inner{display:flex;justify-content:space-between}.footer a{color:#fff;text-decoration:none}.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:none}@media (max-width:860px){.hero-image-wrap{min-height:420px}.hero-lockers-img{height:420px}..nav-toggle{display:block}.nav-links{display:none;position:absolute;top:78px;left:4%;right:4%;padding:18px;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);flex-direction:column;align-items:flex-start}.nav-links.open{display:flex}.hero-grid,.split-grid,.contact-grid{grid-template-columns:1fr;gap:38px}.three,.four{grid-template-columns:1fr}.section-pad{padding:68px 0}.hero-actions,.footer-inner{flex-direction:column}.stats{grid-template-columns:1fr}.floating-card{right:10px}.brand-text{font-size:15px}}

/* Project cards + popup details */
.project-card{display:flex;flex-direction:column;text-decoration:none;transition:transform .22s ease,background .22s ease,border-color .22s ease}.project-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.12);border-color:rgba(246,184,0,.45)}.read-more{margin-top:auto;color:var(--gold);font-weight:900;font-size:14px;background:transparent;border:0;padding:0;text-align:left;cursor:pointer;font:inherit}.read-more:hover{text-decoration:underline}.placeholder-photo{min-height:310px;border-radius:22px;background:linear-gradient(135deg,#eef2f6,#dfe7ef);display:grid;place-items:center;text-align:center;color:var(--muted);font-weight:800;border:1px dashed #b8c4d2}.project-modal{position:fixed;inset:0;z-index:100;display:none}.project-modal.is-open{display:block}.project-modal-backdrop{position:absolute;inset:0;background:rgba(3,29,53,.72);backdrop-filter:blur(8px)}.project-modal-panel{position:relative;width:min(980px,92%);max-height:88vh;margin:6vh auto;background:#fff;color:var(--navy);border-radius:var(--radius);box-shadow:0 30px 90px rgba(0,0,0,.35);padding:26px;display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;overflow:auto}.modal-close{position:absolute;top:14px;right:16px;width:42px;height:42px;border:0;border-radius:999px;background:var(--navy);color:#fff;font-size:28px;line-height:1;cursor:pointer}.modal-copy{padding:16px 8px 8px}.modal-copy h3{font-size:clamp(28px,4vw,44px);line-height:1.04;margin-bottom:16px}.modal-copy p{color:var(--muted);font-size:17px}.body-lock{overflow:hidden}
@media (max-width:860px){.project-modal-panel{grid-template-columns:1fr;margin:4vh auto;max-height:92vh}.placeholder-photo{min-height:220px}}


/* Scrollable project image galleries */
.modal-gallery{background:#f6f8fb;border:1px solid var(--line);border-radius:22px;overflow:hidden;min-height:360px}
.modal-gallery-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:14px;max-height:64vh}
.gallery-item{margin:0;flex:0 0 min(720px,86vw);scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 10px 26px rgba(3,29,53,.08)}
.gallery-item img{display:block;width:100%;height:min(520px,58vh);object-fit:contain;background:#eef2f6}
.gallery-item figcaption{padding:10px 14px;color:var(--muted);font-size:13px;font-weight:700}
.project-modal-panel{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,.9fr);gap:24px}
@media (max-width:860px){.project-modal-panel{grid-template-columns:1fr}.modal-gallery{min-height:260px}.gallery-item{flex-basis:82vw}.gallery-item img{height:320px}}

.hardware-visual{min-height:560px;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;background:#f6f7f9;display:flex;align-items:center;justify-content:center}.hardware-visual img{width:100%;height:560px;display:block;object-fit:cover;object-position:center}

/* v5 restored typography + compact popup galleries */
.modal-gallery{
  background:#f6f8fb;
  border:1px solid var(--line);
  border-radius:22px;
  overflow:hidden;
  min-height:0;
}
.modal-gallery-track{
  display:flex;
  gap:8px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:8px;
  max-height:70vh;
  align-items:stretch;
}
.gallery-item{
  margin:0;
  flex:0 0 100%;
  scroll-snap-align:start;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 8px 22px rgba(3,29,53,.08);
}
.gallery-item img{
  display:block;
  width:100%;
  height:min(500px,62vh);
  object-fit:cover;
  object-position:center;
  background:#fff;
}
.gallery-item figcaption{
  padding:8px 12px;
  color:var(--muted);
  font-size:12px;
  font-weight:700;
  line-height:1.25;
}
@media (max-width:860px){
  .modal-gallery-track{gap:6px;padding:6px;max-height:60vh}
  .gallery-item{flex-basis:100%}
  .gallery-item img{height:320px;object-fit:cover}
}


/* v8: larger hardware image and better balance */
@media (min-width:861px){
  .hardware-section .split-grid{
    grid-template-columns:minmax(540px,1.12fr) minmax(430px,.88fr);
    gap:56px;
  }
  .hardware-visual{
    min-height:660px;
  }
  .hardware-visual img{
    height:660px;
    object-fit:cover;
    object-position:center center;
  }
}
@media (max-width:860px){
  .hardware-visual{min-height:460px;}
  .hardware-visual img{height:460px;}
}


/* v9 SEO + mobile + performance refinements */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{overflow-x:hidden;}
img{max-width:100%;height:auto;}
a,button,input,textarea{touch-action:manipulation;}
section{scroll-margin-top:92px;}
.noscript-message{padding:16px;text-align:center;background:#fff3cd;color:#3b2b00;font-weight:700;margin:0;}

/* Better readable titles on mobile */
@media (max-width: 720px){
  .section-pad{padding:64px 0;}
  .hero{padding-top:86px;}
  .hero-grid,.split-grid,.contact-grid{grid-template-columns:1fr!important;gap:30px;}
  .hero-copy h1{font-size:clamp(38px,10.5vw,54px);line-height:1.02;letter-spacing:-1.8px;}
  .lead{font-size:17px;line-height:1.6;}
  .hero-actions{display:grid;grid-template-columns:1fr;gap:12px;}
  .btn{width:100%;justify-content:center;min-height:48px;}
  .stats{grid-template-columns:1fr;gap:10px;}
  .cards.three,.cards.four,.project-grid{grid-template-columns:1fr!important;gap:18px;}
  .card,.location-card{padding:24px;}
  .section-head h2,.split h2,.contact-grid h2{font-size:clamp(30px,8vw,42px);line-height:1.08;}
  .brand-text{font-size:18px;}
  .brand-logo{width:46px;height:auto;}
  .nav{min-height:70px;}
  .nav-links{top:70px;}
  .hero-image-wrap{border-radius:24px;}
  .floating-card{left:12px;right:12px;bottom:12px;width:auto;}
  .hardware-visual{min-height:0!important;border-radius:24px;}
  .hardware-visual img{height:auto!important;max-height:none!important;object-fit:contain;background:#fff;}
  .timeline div{padding:20px;}
  .contact-form{padding:22px;}
  .modal-copy{padding:6px 2px 0;}
  .project-modal-panel{width:min(94vw,1100px);max-height:90vh;padding:18px;border-radius:22px;overflow:auto;}
  .modal-close{top:10px;right:10px;min-width:44px;min-height:44px;}
  .gallery-item img{height:auto!important;max-height:58vh;object-fit:contain;}
}

@media (max-width: 420px){
  .container{width:min(100% - 28px, var(--max));}
  .hero-copy h1{font-size:36px;letter-spacing:-1.2px;}
  .section-head h2,.split h2,.contact-grid h2{font-size:30px;}
  .nav-links{left:14px;right:14px;}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important;}
}

.hidden-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important}.form-note{margin:14px 0 0;color:var(--muted);font-size:14px}.form-note.success{color:#147a3d;font-weight:700}.form-note.error{color:#b42318;font-weight:700}.contact-form button[disabled]{opacity:.65;cursor:not-allowed}


/* Formspree success screen */
.form-success-panel{
  min-height:420px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:14px;
  padding:34px 24px;
}
.success-icon{
  width:86px;
  height:86px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:#18a058;
  color:#fff;
  font-size:46px;
  font-weight:900;
  box-shadow:0 18px 36px rgba(24,160,88,.22);
}
.form-success-panel h3{
  margin:8px 0 0;
  font-size:clamp(28px,3vw,38px);
  line-height:1.05;
}
.form-success-panel p{
  max-width:420px;
  margin:0 0 8px;
  color:var(--muted);
  font-size:17px;
}
.form-success-panel .btn.secondary{
  margin-top:6px;
}

/* v12 mobile redesign: readable, logical and no horizontal cut-off */
.container{
  width:100%;
  max-width:1160px;
  padding-left:clamp(18px,4vw,32px);
  padding-right:clamp(18px,4vw,32px);
}

@media (max-width: 860px){
  body{overflow-x:hidden;background:#fff;}
  .site-header{background:#fff;}
  .nav{
    height:74px;
    min-height:74px;
    padding:0;
    gap:12px;
  }
  .brand{gap:10px;min-width:0;}
  .brand-logo{width:50px;height:39px;flex:0 0 auto;}
  .brand-text{
    font-size:20px;
    letter-spacing:.02em;
    white-space:nowrap;
    line-height:1;
  }
  .nav-toggle{
    display:flex;
    align-items:center;
    justify-content:center;
    width:46px;
    height:42px;
    padding:0;
    flex:0 0 auto;
  }
  .nav-links{
    top:74px;
    left:18px;
    right:18px;
    padding:18px;
    gap:14px;
    z-index:30;
  }
  .nav-links a{font-size:16px;}

  .section-pad{padding:56px 0;}
  .hero{
    padding-top:42px;
    background:linear-gradient(180deg,#fff7df 0%,#fff 76%);
  }
  .hero-grid{
    display:grid;
    grid-template-columns:1fr!important;
    gap:28px;
    align-items:start;
  }
  .hero-copy{width:100%;min-width:0;}
  .eyebrow{
    font-size:11px;
    letter-spacing:.16em;
    line-height:1.4;
    margin-bottom:12px;
  }
  .hero-copy h1{
    font-size:clamp(34px,9.2vw,46px)!important;
    line-height:1.08!important;
    letter-spacing:-.035em!important;
    margin-bottom:18px;
    max-width:100%;
    overflow-wrap:normal;
  }
  .lead{
    font-size:17px!important;
    line-height:1.58;
    color:#5f7086;
  }
  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    margin:28px 0 24px;
  }
  .btn{
    width:100%;
    min-height:54px;
    font-size:16px;
    border-radius:999px;
  }
  .stats{
    display:grid;
    grid-template-columns:1fr;
    gap:12px;
    max-width:none;
    margin-top:8px;
  }
  .stats div{
    padding:18px 20px;
    border-radius:18px;
  }
  .stats strong{font-size:26px;line-height:1.1;}
  .stats span{font-size:14px;}

  .hero-visual{order:2;width:100%;min-width:0;}
  .hero-image-wrap{
    min-height:0!important;
    height:auto;
    border-radius:24px;
  }
  .hero-lockers-img{
    height:auto!important;
    aspect-ratio:4/3;
    object-fit:cover;
    object-position:center;
  }
  .floating-card{
    position:relative;
    left:auto;
    right:auto;
    bottom:auto;
    margin:12px 0 0;
    width:100%;
    border-radius:18px;
    padding:16px 18px;
    box-shadow:0 10px 28px rgba(3,29,53,.10);
  }

  .section-head{margin-bottom:26px;}
  .section-head h2,
  .split h2,
  .contact-grid h2{
    font-size:clamp(30px,8vw,40px)!important;
    line-height:1.1!important;
    letter-spacing:-.035em!important;
  }
  .section-head p:not(.eyebrow){font-size:17px;line-height:1.55;}
  .cards.three,.cards.four,.project-grid{grid-template-columns:1fr!important;}
  .card,.location-card,.contact-form{padding:22px;border-radius:22px;}

  .hardware-section .split-grid{grid-template-columns:1fr!important;gap:28px;}
  .hardware-visual{
    min-height:0!important;
    border-radius:24px;
  }
  .hardware-visual img{
    width:100%;
    height:auto!important;
    display:block;
    object-fit:contain!important;
    object-position:center!important;
  }
  .timeline{gap:14px;}
  .timeline div{
    grid-template-columns:44px 1fr;
    gap:0 14px;
    padding:18px;
    border-radius:20px;
  }
  .timeline b{width:44px;height:44px;border-radius:14px;}
  .timeline h3{font-size:19px;margin-bottom:6px;}
  .timeline p{font-size:15px;line-height:1.5;}

  .project-modal-panel{
    width:calc(100vw - 24px);
    margin:12px auto;
    max-height:calc(100vh - 24px);
    padding:14px;
    border-radius:22px;
    grid-template-columns:1fr!important;
    gap:16px;
  }
  .modal-close{top:10px;right:10px;z-index:2;}
  .modal-copy h3{font-size:30px;line-height:1.08;}
  .modal-copy p{font-size:16px;line-height:1.55;}
  .modal-gallery-track{padding:6px;gap:6px;max-height:none;}
  .gallery-item{flex:0 0 100%;border-radius:14px;}
  .gallery-item img{height:auto!important;max-height:56vh;object-fit:contain!important;background:#f5f7fa;}

  .contact-grid{grid-template-columns:1fr!important;gap:26px;}
  .footer-inner{gap:10px;text-align:center;align-items:center;}
}

@media (max-width: 430px){
  .container{padding-left:20px;padding-right:20px;}
  .brand-logo{width:44px;height:35px;}
  .brand-text{font-size:18px;}
  .hero-copy h1{font-size:35px!important;line-height:1.08!important;}
  .lead{font-size:16.5px!important;}
  .section-pad{padding:50px 0;}
}

@media (max-width: 360px){
  .brand-text{font-size:16px;}
  .hero-copy h1{font-size:31px!important;}
}

/* v13 mobile structure fix: title -> image -> description -> small stats -> buttons */
.mobile-hero-image{display:none;}
@media (max-width: 760px){
  body{overflow-x:hidden;}
  .container{width:min(100% - 28px, 560px);}
  .site-header{position:sticky;top:0;}
  .nav{height:72px;}
  .brand-logo{width:46px;height:36px;}
  .brand-text{font-size:16px;letter-spacing:.02em;}

  .hero{padding-top:0;background:linear-gradient(180deg,#fffaf0 0%,#fff 68%,#f6f8fb 100%);}
  .hero.section-pad{padding:48px 0 56px;}
  .hero-grid{display:block!important;}
  .hero-copy{display:flex!important;flex-direction:column;align-items:stretch;}
  .hero-copy .eyebrow{font-size:11px;letter-spacing:.16em;text-align:left;margin-bottom:12px;}
  .hero-copy h1{font-size:clamp(34px, 9.4vw, 45px)!important;line-height:1.06!important;letter-spacing:-1.25px!important;margin:0 0 20px!important;max-width:100%;}

  .hero-visual{display:none!important;}
  .mobile-hero-image{display:block;margin:0 0 20px;width:100%;border-radius:24px;overflow:hidden;box-shadow:0 18px 48px rgba(3,29,53,.14);background:#eef2f6;}
  .mobile-hero-image img{display:block;width:100%;height:auto;min-height:260px;max-height:380px;object-fit:cover;object-position:center center;}
  .lead{font-size:18px!important;line-height:1.55!important;margin:0 0 18px!important;color:#586a80;}

  .stats{order:4;display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:8px!important;margin:2px 0 20px!important;max-width:none!important;}
  .stats div{padding:12px 8px!important;border-radius:16px!important;text-align:center;background:#fff;border:1px solid var(--line);}
  .stats strong{font-size:18px!important;line-height:1.05!important;white-space:nowrap;}
  .stats span{font-size:11px!important;line-height:1.2!important;display:block;margin-top:4px;}
  .hero-actions{order:5;display:grid!important;grid-template-columns:1fr!important;gap:12px!important;margin:0!important;}
  .hero-actions .btn{width:100%;min-height:56px;font-size:16px;}

  .hardware-section .split-grid{display:block!important;}
  .hardware-visual{width:100%!important;margin:0 0 26px!important;border-radius:24px!important;min-height:0!important;box-shadow:0 18px 48px rgba(3,29,53,.12)!important;background:#f4f6f8!important;}
  .hardware-visual img{width:100%!important;height:auto!important;min-height:300px!important;max-height:none!important;object-fit:cover!important;object-position:center center!important;display:block!important;}
}

@media (max-width: 390px){
  .container{width:min(100% - 22px, 560px);}
  .hero-copy h1{font-size:32px!important;}
  .mobile-hero-image img{min-height:240px;}
  .stats strong{font-size:16px!important;}
  .stats span{font-size:10px!important;}
}

/* v14 mobile hero overlay refinement */
@media (max-width: 760px){
  .hero.section-pad{padding:34px 0 54px!important;}
  .hero-copy .eyebrow{order:1;margin-bottom:10px!important;}
  .hero-copy h1{
    order:2;
    position:relative;
    z-index:3;
    width:calc(100% - 18px);
    align-self:center;
    background:rgba(255,255,255,.90);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    padding:16px 16px 18px;
    border:1px solid rgba(219,227,236,.82);
    border-radius:22px;
    box-shadow:0 16px 42px rgba(3,29,53,.14);
    margin:0 auto -34px!important;
    font-size:clamp(31px,8.7vw,42px)!important;
    line-height:1.04!important;
    letter-spacing:-1.3px!important;
  }
  .mobile-hero-image{
    order:3;
    margin:0 0 18px!important;
    border-radius:26px!important;
    box-shadow:0 22px 56px rgba(3,29,53,.17)!important;
  }
  .mobile-hero-image img{
    width:100%!important;
    height:360px!important;
    min-height:360px!important;
    max-height:360px!important;
    object-fit:cover!important;
    object-position:center center!important;
  }
  .lead{order:4;background:rgba(255,255,255,.72);border-radius:18px;padding:2px 2px 0;margin:0 0 16px!important;}
  .stats{order:5!important;margin:0 0 20px!important;}
  .hero-actions{order:6!important;}
}

@media (max-width: 430px){
  .mobile-hero-image img{height:330px!important;min-height:330px!important;max-height:330px!important;}
  .hero-copy h1{font-size:clamp(29px,8.5vw,38px)!important;margin-bottom:-28px!important;padding:14px 14px 16px;}
}

@media (max-width: 360px){
  .hero-copy h1{font-size:28px!important;}
  .mobile-hero-image img{height:300px!important;min-height:300px!important;max-height:300px!important;}
}

/* v15 mobile: readable text overlay WITHOUT white box */
@media (max-width: 760px){
  .hero.section-pad{padding:32px 0 54px!important;}
  .hero-copy h1{
    order:2!important;
    position:relative!important;
    z-index:4!important;
    width:100%!important;
    align-self:stretch!important;
    background:transparent!important;
    backdrop-filter:none!important;
    -webkit-backdrop-filter:none!important;
    border:0!important;
    border-radius:0!important;
    box-shadow:none!important;
    padding:0 10px!important;
    margin:0 0 -74px!important;
    color:#ffffff!important;
    text-shadow:0 3px 14px rgba(3,29,53,.70), 0 1px 2px rgba(3,29,53,.92)!important;
    font-size:clamp(31px,8.8vw,42px)!important;
    line-height:1.04!important;
    letter-spacing:-1.35px!important;
  }
  .mobile-hero-image{
    position:relative!important;
    order:3!important;
    margin:0 0 18px!important;
    border-radius:26px!important;
    overflow:hidden!important;
    box-shadow:0 22px 56px rgba(3,29,53,.17)!important;
  }
  .mobile-hero-image::after{
    content:"";
    position:absolute;
    inset:0;
    pointer-events:none;
    background:linear-gradient(180deg, rgba(3,29,53,.48) 0%, rgba(3,29,53,.22) 35%, rgba(3,29,53,0) 68%);
  }
  .mobile-hero-image img{
    width:100%!important;
    height:370px!important;
    min-height:370px!important;
    max-height:370px!important;
    object-fit:cover!important;
    object-position:center center!important;
  }
  .lead{
    order:4!important;
    background:transparent!important;
    border-radius:0!important;
    padding:0!important;
    margin:0 0 16px!important;
  }
}
@media (max-width:430px){
  .hero-copy h1{
    margin-bottom:-68px!important;
    padding:0 8px!important;
    font-size:clamp(29px,8.6vw,38px)!important;
  }
  .mobile-hero-image img{height:340px!important;min-height:340px!important;max-height:340px!important;}
}
@media (max-width:360px){
  .hero-copy h1{font-size:28px!important;margin-bottom:-62px!important;}
  .mobile-hero-image img{height:315px!important;min-height:315px!important;max-height:315px!important;}
}

/* v16: make the hardware/support image much bigger on mobile */
@media (max-width: 760px){
  .hardware-section{padding-top:54px!important;}
  .hardware-section .container{width:100%!important;max-width:none!important;padding-left:14px!important;padding-right:14px!important;}
  .hardware-section .split-grid{display:flex!important;flex-direction:column!important;gap:28px!important;}
  .hardware-visual{
    width:100%!important;
    max-width:none!important;
    margin:0 auto 24px!important;
    border-radius:26px!important;
    overflow:hidden!important;
    background:#f4f6f8!important;
    min-height:0!important;
    box-shadow:0 22px 58px rgba(3,29,53,.14)!important;
  }
  .hardware-visual img{
    width:100%!important;
    height:clamp(430px, 92vw, 560px)!important;
    min-height:430px!important;
    max-height:560px!important;
    display:block!important;
    object-fit:cover!important;
    object-position:center center!important;
  }
}
@media (max-width:430px){
  .hardware-section .container{padding-left:10px!important;padding-right:10px!important;}
  .hardware-visual{border-radius:24px!important;}
  .hardware-visual img{
    height:clamp(390px, 108vw, 500px)!important;
    min-height:390px!important;
    max-height:500px!important;
    object-position:center center!important;
  }
}
@media (max-width:360px){
  .hardware-visual img{height:380px!important;min-height:380px!important;}
}
