/* archiHARBOUR Solutions Ltd — Main Stylesheet */
:root{--r:#CC0000;--rd:#AA0000;--k:#111111;--w:#ffffff;--g:#f5f5f5;--mu:#666666;--bd:#e0e0e0;--bdd:#cccccc;--max:1080px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Lato',system-ui,sans-serif;font-weight:400;color:#222;background:var(--w);line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit}
.inner{max-width:var(--max);margin:0 auto;padding:0 2rem}
/* Labels */
.lbl{display:inline-flex;align-items:center;gap:.5rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:var(--r)}
.lbl::before{content:'';display:block;width:7px;height:7px;background:var(--r);border-radius:1px;flex-shrink:0}
/* Section header row */
.sec-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2rem}
.va{background:none;border:none;font:.65rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--k)}
.va::after{content:'\00a0\2192';color:var(--r)}
.va:hover{color:var(--r)}
/* Bullets */
.dl-list{list-style:none;padding:0;margin-top:.9rem}
li.dl{display:flex;align-items:flex-start;gap:.6rem;font-size:.97rem;font-weight:300;color:#444;padding:.28rem 0;line-height:1.55}
li.dl::before{content:'';display:block;width:6px;height:6px;background:var(--r);border-radius:1px;flex-shrink:0;margin-top:.48em}
/* Buttons */
.btn-r{display:inline-block;background:var(--r);color:var(--w);border:none;padding:.7rem 1.9rem;font:.76rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:1px;transition:background .2s,transform .15s}
.btn-r:hover{background:var(--rd);transform:translateY(-1px)}
.btn-w{display:inline-block;background:transparent;color:var(--w);border:1.5px solid rgba(255,255,255,.42);padding:.7rem 1.9rem;font:.76rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:1px;transition:border-color .2s,background .2s,transform .15s}
.btn-w:hover{border-color:var(--w);background:rgba(255,255,255,.1);transform:translateY(-1px)}
.btn-k{display:inline-block;background:var(--k);color:var(--w);border:none;padding:.7rem 1.9rem;font:.76rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:1px;transition:background .2s}
.btn-k:hover{background:#333}
.btn-outline{display:inline-block;background:transparent;color:var(--k);border:1.5px solid var(--k);padding:.65rem 1.8rem;font:.76rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;border-radius:1px;transition:background .2s,color .2s}
.btn-outline:hover{background:var(--k);color:var(--w)}
/* NAV */
.nav{background:var(--w);border-bottom:2px solid var(--k);position:sticky;top:0;z-index:100}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:2rem}
.nl{background:none;border:none;font:.73rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--k);padding:4px 0;position:relative;text-decoration:none;display:inline-block}
.nl::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;background:var(--r);transition:width .2s}
.nl:hover::after,.nl.active::after{width:100%}
.nl-cta{background:none;color:var(--r)!important;padding:0;border-radius:0;text-decoration:none;display:inline-block;font:.73rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;transition:opacity .2s}
.nl-cta:hover{opacity:.7}
/* Dark hero */
.dark-hero{background:var(--k);padding:3.5rem 2rem;border-bottom:3px solid var(--r)}
.dark-hero h1{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:900;color:var(--w);letter-spacing:-.01em;margin-top:.55rem;line-height:1.1}
.dark-hero p{font-size:.97rem;font-weight:300;color:rgba(255,255,255,.55);margin-top:.6rem;max-width:560px;line-height:1.75}
/* Homepage hero */
.hero{position:relative;height:88vh;min-height:540px;display:flex;align-items:flex-end;overflow:hidden;background:#1a1a1a}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;animation:heroZoom 14s ease-out forwards}
@keyframes heroZoom{from{transform:scale(1.05)}to{transform:scale(1)}}
.hero-dim{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.42) 55%,rgba(0,0,0,.08) 100%)}
.hero-rb{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--r)}
.hero-c{position:relative;width:100%;max-width:var(--max);margin:0 auto;padding:0 2rem 5rem}
.hero-eye{display:inline-flex;align-items:center;gap:.5rem;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:rgba(255,255,255,.42);margin-bottom:1.1rem}
.hero-eye::before{content:'';display:block;width:7px;height:7px;background:var(--r);border-radius:1px}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:900;color:var(--w);line-height:1.05;letter-spacing:-.02em;margin-bottom:1rem}
.hero h1 em{font-style:normal;color:var(--r)}
.hero-sub{font-size:1rem;font-weight:300;color:rgba(255,255,255,.7);max-width:460px;line-height:1.75;margin-bottom:2rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap}
/* Service tabs */
.services{padding:3.5rem 2rem;background:var(--g);border-bottom:1px solid var(--bd)}
.stabs{display:grid;grid-template-columns:repeat(4,1fr);border:1.5px solid var(--bdd);border-radius:2px;overflow:hidden}
.st{background:var(--w);border:none;border-right:1px solid var(--bd);padding:1.1rem 1rem;text-align:left;display:flex;flex-direction:column;gap:.45rem;transition:background .22s;width:100%}
.st:last-child{border-right:none}
.st.on{background:var(--k)}
.st svg{color:var(--r);width:28px;height:28px}
.st-label{font-size:.62rem;font-weight:900;text-transform:uppercase;letter-spacing:.07em;color:var(--k);transition:color .22s;line-height:1.3}
.st.on .st-label{color:var(--w)}
.svc-panel{display:none;background:var(--w);border:1.5px solid var(--bdd);border-top:none;padding:1.6rem 2rem;gap:1.6rem}
.svc-panel.on{display:grid;grid-template-columns:1fr 1fr}
.svc-panel p{font-size:.95rem;font-weight:300;color:var(--mu);line-height:1.8}
/* Project tiles home */
.projs{padding:3.5rem 2rem}
.ptg{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;height:210px}
.pt{position:relative;overflow:hidden;background:#999}
.pt img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s;filter:grayscale(8%)}
.pt:hover img{transform:scale(1.07);filter:grayscale(0%)}
.pt-tag{position:absolute;top:.6rem;left:.6rem;background:var(--r);color:var(--w);font-size:.52rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.15rem .42rem;border-radius:1px;z-index:2}
.pt-cap{position:absolute;bottom:0;left:0;right:0;padding:.75rem .9rem;opacity:0;transition:opacity .28s;background:linear-gradient(to top,rgba(0,0,0,.88),transparent);z-index:2}
.pt-cap::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--r)}
.pt:hover .pt-cap{opacity:1}
.pt-cap h4{font-size:.82rem;font-weight:700;color:var(--w);margin-bottom:.15rem}
.pt-cap span{font-size:.6rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.08em}
/* Client strip */
.clients{padding:2.2rem 0;background:var(--w);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);overflow:hidden}
.clients-lbl{padding:0 2rem;margin-bottom:1.2rem}
.client-track-wrap{overflow:hidden;position:relative}
.client-track-wrap::before,.client-track-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.client-track-wrap::before{left:0;background:linear-gradient(to right,#fff,transparent)}
.client-track-wrap::after{right:0;background:linear-gradient(to left,#fff,transparent)}
.client-track{display:flex;gap:2rem;padding:0 2rem;animation:scrollx 30s linear infinite;width:max-content}
.client-track:hover{animation-play-state:paused}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.client-logo{height:40px;width:auto;object-fit:contain;flex-shrink:0;filter:grayscale(100%);opacity:.55;transition:opacity .2s,filter .2s}
.client-logo:hover{filter:grayscale(0%);opacity:1}
.logo-placeholder{height:36px;background:#e8e8e8;border-radius:2px;flex-shrink:0;opacity:.7}
/* Solutions overview grid */
.sol-overview{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--bd)}
.sov-card{padding:2.2rem 1.8rem;border-right:1px solid var(--bd);position:relative;overflow:hidden;transition:background .22s}
.sov-card:last-child{border-right:none}
.sov-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--r);transform:scaleX(0);transition:transform .3s;transform-origin:left}
.sov-card:hover{background:var(--g)}
.sov-card:hover::after{transform:scaleX(1)}
.sov-num{font-size:2.2rem;font-weight:900;color:rgba(0,0,0,.055);line-height:1;letter-spacing:-.04em;margin-bottom:.8rem}
.sov-icon{margin-bottom:.8rem}
.sov-icon svg{width:32px;height:32px;color:var(--r)}
.sov-title{font-size:.9rem;font-weight:900;color:var(--k);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}
.sov-line{font-size:.84rem;font-weight:300;color:var(--mu);line-height:1.6}
.sov-arrow{display:block;margin-top:1rem;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--r)}
.sol-divider{background:var(--k);padding:.8rem 2rem;display:flex;align-items:center;justify-content:space-between}
.sol-divider span{font-size:.85rem;font-weight:900;text-transform:uppercase;letter-spacing:.18em;color:#ffffff}
.sol-divider .inner-div{max-width:1080px;margin:0 auto;width:100%;display:flex;align-items:center}
.sol-divider em{font-style:normal;font-size:.62rem;color:rgba(255,255,255,.22)}
/* Solutions detail */
.svc-block{padding:3.5rem 2rem;border-bottom:1px solid var(--bd)}
.svc-block:nth-child(even){background:#fafafa}
.svc-bi{display:grid;grid-template-columns:1fr 1fr;gap:2.8rem;align-items:start}
.svc-block h2{font-size:1.35rem;font-weight:900;color:var(--k);letter-spacing:-.01em;margin-top:.5rem}
.svc-block p{font-size:.95rem;font-weight:300;color:var(--mu);line-height:1.8;margin-top:.55rem}
.pmg{display:grid;grid-template-columns:1fr 1fr;gap:4px;height:160px;border-radius:2px;overflow:hidden}
.pm{position:relative;overflow:hidden;background:#aaa}
.pm img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.pm:hover img{transform:scale(1.06)}
.pm-cap{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,.68);padding:.4rem .6rem;display:flex;justify-content:space-between;align-items:center}
.pm-cap span{font-size:.58rem;color:rgba(255,255,255,.85)}
.pm-cap a{font-size:.52rem;color:var(--r);font-weight:700;text-transform:uppercase;letter-spacing:.08em;text-decoration:none}
.icon-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;height:160px;border-radius:2px;overflow:hidden}
.icon-tile{background:var(--k);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;padding:1rem}
.icon-tile svg{color:var(--r);width:36px;height:36px}
.icon-tile span{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.6);text-align:center;line-height:1.4}
/* Projects page */
.proj-filter{padding:1.1rem 2rem;background:var(--g);border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.pf{background:none;border:1.5px solid var(--bd);font:.63rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--mu);padding:.38rem .95rem;border-radius:1px;transition:all .2s}
.pf.on{background:var(--k);border-color:var(--k);color:var(--w)}
.pf:hover:not(.on){border-color:var(--r);color:var(--r)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px}
.proj-card{position:relative;overflow:hidden;background:#999;height:210px}
.proj-card:first-child{grid-column:span 2;height:290px}
.proj-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s;filter:grayscale(8%)}
.proj-card:hover img{transform:scale(1.07);filter:grayscale(0%)}
.proj-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--r);transition:width .25s;z-index:1}
.proj-card:hover::before{width:3px}
.proj-meta{position:absolute;bottom:0;left:0;right:0;padding:.9rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);z-index:2}
.proj-meta h4{font-size:.84rem;font-weight:700;color:var(--w);margin-bottom:.25rem}
.proj-meta-row{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}
.proj-meta-row span{font-size:.58rem;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.08em}
.proj-meta-row .yr{color:var(--r);font-weight:700}
.proj-tag2{position:absolute;top:.6rem;left:.6rem;background:var(--r);color:var(--w);font-size:.52rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.15rem .42rem;border-radius:1px;z-index:2}
/* Contact */
.con-wrap{max-width:var(--max);margin:0 auto;padding:3rem 2rem;display:grid;grid-template-columns:3fr 2fr;gap:3.5rem}
.con-form label{display:block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--r);margin:.9rem 0 .28rem}
.con-form label:first-child{margin-top:0}
.con-form input,.con-form textarea{width:100%;border:1.5px solid var(--bd);padding:.58rem .78rem;font:.88rem/1.4 'Lato',system-ui;color:var(--k);border-radius:1px;outline:none;display:block;transition:border-color .2s}
.con-form input:focus,.con-form textarea:focus{border-color:var(--r)}
.con-form textarea{height:92px;resize:none}
.con-char{font-size:.62rem;color:#aaa;margin-top:.22rem}
.error-bar{display:none;background:#fff0f0;border:1px solid #ffcccc;padding:.6rem .8rem;font-size:.8rem;color:var(--r);margin-top:.8rem;border-radius:1px}
.success-screen{display:none;padding:3rem 0;text-align:center}
.success-screen h3{font-size:1.2rem;font-weight:900;color:var(--k);margin-bottom:.5rem}
.success-screen p{font-size:.95rem;font-weight:300;color:var(--mu)}
.off-sidebar h3{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;color:var(--r);margin-bottom:1.2rem}
.off-item{border-left:2px solid var(--r);padding-left:.9rem;margin-bottom:1.1rem}
.off-city{font-size:.97rem;font-weight:900;color:var(--k);letter-spacing:-.01em}
.off-addr{font-size:.82rem;font-weight:300;color:var(--mu);line-height:1.6;margin-top:.15rem}
/* Footer */
.footer{background:var(--k);padding:1.6rem 2rem}
.footer-inner{max-width:var(--max);margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.9rem}
.footer-logo img{height:26px;width:auto;filter:brightness(0) invert(1)}
.footer-copy{font-size:.68rem;color:rgba(255,255,255,.3);font-weight:300}
.footer-links{display:flex;gap:1.6rem;align-items:center;flex-wrap:wrap}
.fl{background:none;border:none;font:.62rem/1 'Lato',system-ui;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.42);text-decoration:none;display:inline-block;transition:color .2s}
.fl:hover{color:var(--r)}
/* Utility pages */
.util-body{max-width:720px;margin:0 auto;padding:3.5rem 2rem}
.util-body h2{font-size:1.3rem;font-weight:900;color:var(--k);letter-spacing:-.01em;margin:2rem 0 .6rem}
.util-body h2:first-child{margin-top:0}
.util-body h3{font-size:1rem;font-weight:900;color:var(--k);margin:1.5rem 0 .4rem}
.util-body p{font-size:.95rem;font-weight:300;color:#444;line-height:1.8;margin-bottom:.7rem}
.util-body ul{list-style:none;padding:0;margin:.5rem 0 1rem}
.util-body ul li{display:flex;align-items:flex-start;gap:.6rem;font-size:.95rem;font-weight:300;color:#444;padding:.25rem 0;line-height:1.55}
.util-body ul li::before{content:'';display:block;width:6px;height:6px;background:var(--r);border-radius:1px;flex-shrink:0;margin-top:.5em}
.util-divider{border:none;border-top:1px solid var(--bd);margin:2rem 0}
/* Deck */
.deck-stat{display:inline-flex;align-items:baseline;gap:.3rem;margin-right:1.5rem;margin-bottom:.5rem}
.deck-stat .n{font-size:2rem;font-weight:900;color:var(--r);line-height:1}
.deck-stat .l{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--mu)}
.deck-services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}
.deck-svc{border:1.5px solid var(--bd);border-radius:2px;padding:1.2rem 1.4rem}
.deck-svc h3{font-size:.85rem;font-weight:900;color:var(--k);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}
.deck-svc p{font-size:.82rem;font-weight:300;color:var(--mu);line-height:1.65}
/* Checklist */
.checklist{list-style:none;padding:0;margin:1rem 0}
.checklist li{display:grid;grid-template-columns:auto 1fr;gap:.8rem;padding:.65rem 0;border-bottom:1px solid var(--bd);align-items:flex-start}
.checklist li:last-child{border-bottom:none}
.checklist input[type=checkbox]{width:18px;height:18px;border:1.5px solid var(--bd);border-radius:2px;flex-shrink:0;margin-top:.1em;cursor:pointer;accent-color:var(--r)}
.checklist .item-text{font-size:.95rem;font-weight:300;color:#333;line-height:1.5}
.checklist .item-text strong{font-weight:700;display:block;margin-bottom:.15rem}
/* Password page */
.pw-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:3rem 2rem}
.pw-box{background:var(--w);border:1.5px solid var(--bd);padding:2.5rem 2rem;border-radius:2px;width:100%;max-width:360px;text-align:center;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.pw-box h2{font-size:1.1rem;font-weight:900;color:var(--k);margin-bottom:.4rem}
.pw-box p{font-size:.82rem;font-weight:300;color:var(--mu);margin-bottom:1.2rem;line-height:1.65}
.pw-input{width:100%;border:1.5px solid var(--bd);padding:.58rem .78rem;font:.88rem/1.4 'Lato',system-ui;color:var(--k);border-radius:1px;outline:none;margin-bottom:.7rem;text-align:center;letter-spacing:.2em;transition:border-color .2s}
.pw-input:focus{border-color:var(--r)}
.pw-error{color:var(--r);font-size:.75rem;margin-top:.4rem;display:none}
.protected-content{display:none}
/* Responsive */
@media(max-width:900px){
  .stabs{grid-template-columns:repeat(2,1fr)}
  .st:nth-child(2){border-right:none}
  .svc-panel.on{grid-template-columns:1fr}
  .ptg{grid-template-columns:repeat(2,1fr);height:auto}
  .ptg .pt{height:180px}
  .sol-overview{grid-template-columns:repeat(2,1fr)}
  .sov-card:nth-child(2){border-right:none}
  .sov-card:nth-child(1),.sov-card:nth-child(2){border-bottom:1px solid var(--bd)}
  .svc-bi{grid-template-columns:1fr}
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .proj-card:first-child{grid-column:span 2;height:240px}
  .con-wrap{grid-template-columns:1fr}
  .deck-services-grid{grid-template-columns:1fr}
  .nav-links{gap:1.2rem}
}
@media(max-width:600px){
  .nav-inner,.hero-c,.services,.projs,.svc-block,.dark-hero,.footer,.proj-filter,.con-wrap,.util-body{padding-left:1.2rem;padding-right:1.2rem}
  .sol-overview{grid-template-columns:1fr 1fr}
  .proj-grid{grid-template-columns:1fr}
  .proj-card:first-child{grid-column:span 1}
  .footer-inner{flex-direction:column;align-items:flex-start}
  .stabs{grid-template-columns:repeat(2,1fr)}
}

/* ── Width constraints fix ── */
.services .sec-hdr,
.services .stabs,
.services .svc-panel {
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.projs .sec-hdr,
.projs .ptg {
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.sol-overview {
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.svc-block .svc-bi {
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.proj-filter,
.proj-grid {
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

.clients-lbl,
.client-track-wrap {
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
}

/* ── Client strip — static centred ── */
.clients-static {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  padding: 0 2rem;
  flex-wrap: nowrap;
  overflow: hidden;
}

/* ── Footer link separators ── */
.footer-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.fl {
  border-right: 1px solid rgba(255,255,255,.1);
  padding: 0 .9rem;
}
.fl:first-child { padding-left: 0; }
.fl:last-child { border-right: none; padding-right: 0; }
