.elementor-17 .elementor-element.elementor-element-3f08b23{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-3f08b23 */@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&display=swap');

.sph-hero{padding:64px 0 0;border-bottom:2px solid var(--ink)}
.sph-wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.sph-eyebrow{display:inline-flex;align-items:center;gap:12px;font-family:'Archivo',sans-serif;font-weight:600;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink);margin-bottom:24px}
.sph-eyebrow::before{content:"";width:34px;height:2px;background:var(--accent)}
.sph-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;align-items:center}
.sph-hero h1{font-size:clamp(42px,6vw,86px);font-weight:900;text-transform:uppercase;letter-spacing:-.04em;line-height:.98}
.sph-hero h1 em{font-style:normal;color:var(--accent)}
.sph-stand{margin-top:24px;max-width:540px;font-size:18.5px;color:var(--soft);font-weight:300}
.sph-stand strong{color:var(--ink);font-weight:600}
.sph-search{display:flex;margin-top:30px;border:2px solid var(--ink);max-width:560px;background:var(--card);border-radius:0}
.sph-search input{flex:1;border:none;background:transparent;padding:17px 20px;font-family:'Inter',sans-serif;font-size:15.5px;color:var(--ink);outline:none;border-radius:0}
.sph-search input::placeholder{color:var(--dim)}
.sph-search button{border:none;background:#C4421A;color:#fff;font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;padding:0 26px;cursor:pointer;display:flex;align-items:center;gap:9px;transition:background .25s;border-radius:0}
.sph-search button:hover{background:var(--accent-2)}
.sph-qlinks{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:16px}
.sph-qlinks-label{font-family:'Archivo',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);font-weight:600}
.sph-qlinks a{font-family:'Archivo',sans-serif;font-size:12px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--soft);border-bottom:1px solid var(--line);padding-bottom:2px;transition:color .2s,border-color .2s}
.sph-qlinks a:hover{color:var(--accent);border-color:var(--accent)}
.sph-proofrow{display:flex;align-items:center;gap:22px;flex-wrap:wrap;margin-top:30px;padding-top:26px;border-top:1px solid var(--line)}
.sph-proof-item b{font-family:'Archivo',sans-serif;font-size:22px;font-weight:800;color:var(--ink);display:flex;align-items:center;gap:6px}
.sph-proof-item .sph-stars{color:var(--gold);font-size:14px}
.sph-proof-item span{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);font-family:'Archivo',sans-serif;font-weight:500}
.sph-divider{width:1px;height:38px;background:var(--line)}
.sph-fig{position:relative;aspect-ratio:4/4.6;overflow:hidden;border:2px solid var(--ink)}
.sph-mosaic{position:absolute;inset:0;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:3px;background:var(--ink)}
.sph-cell{position:relative;overflow:hidden;background:var(--paper-2)}
.sph-cell img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .7s var(--ease)}
.sph-cell:hover img{transform:scale(1.08)}
.sph-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(13,12,8,.28),transparent 60%)}
.sph-cell.sph-brand::before{content:"";position:absolute;inset:0;background:var(--accent);mix-blend-mode:multiply;opacity:.66;z-index:1}
.sph-cell.sph-brand img{filter:grayscale(1) contrast(1.06)}
.sph-cell.sph-brand::after{background:none}
.sph-fig .sph-ribbon{position:absolute;top:0;left:0;z-index:3;background:var(--accent);color:#fff;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:9px 15px}
.sph-fig .sph-tagline{position:absolute;left:0;right:0;bottom:0;z-index:3;background:var(--ink);color:var(--paper);padding:14px 18px;display:flex;justify-content:space-between;align-items:center}
.sph-fig .sph-tagline b{font-family:'Archivo',sans-serif;font-style:italic;font-weight:500;font-size:15px}
.sph-fig .sph-tagline span{font-family:'Archivo',sans-serif;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600}
.vstrip{background:var(--ink);color:var(--dk-ink)}
.vstrip .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.vitem{padding:24px 0;border-right:1px solid var(--dk-line);text-align:center}
.vitem:last-child{border-right:none}
.vitem b{font-family:'Archivo',sans-serif;font-weight:800;font-size:15px;text-transform:uppercase;display:block}
.vitem span{color:var(--dk-soft);font-size:12.5px;display:block;font-weight:300;margin-top:3px}
section{position:relative}
.sec{padding:100px 0}
.alt{background:var(--paper-2)}
.ctr{text-align:center;max-width:780px;margin:0 auto 50px}
.ctr .eyebrow{justify-content:center}
.ctr h2{font-size:clamp(32px,4.6vw,62px);font-weight:800;text-transform:uppercase;letter-spacing:-.035em;margin-top:16px}
.ctr h2 em{font-style:normal;color:var(--accent)}
.ctr p{margin-top:16px;color:var(--soft);font-size:17px;font-weight:300}
.invert{background:var(--dk);color:var(--dk-ink)}
.invert h2,.invert h3,.invert h4{color:var(--dk-ink)}
.invert p{color:var(--dk-soft)}
.invert .eyebrow{color:var(--dk-ink)}
.videobox{position:relative;aspect-ratio:16/8;overflow:hidden;border:2px solid var(--ink);cursor:pointer}
.videobox img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.videobox:hover img{transform:scale(1.03)}
.videobox::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(13,12,8,.6),rgba(13,12,8,.18))}
.videobox .play{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.videobox .circ{width:92px;height:92px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;transition:transform .35s var(--ease)}
.videobox:hover .circ{transform:scale(1.08)}
.videobox .circ::after{content:"";margin-left:7px;border-style:solid;border-width:16px 0 16px 26px;border-color:transparent transparent transparent #fff}
.videobox .ptext{color:#fff;font-family:'Archivo',sans-serif;font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}
.dual{display:grid;grid-template-columns:1fr 1fr;border:2px solid var(--dk-ink)}
.dband{padding:46px 40px;border-right:1px solid var(--dk-line)}
.dband:last-child{border-right:none}
.dband .t{font-family:'Archivo',sans-serif;font-weight:800;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.dband h3{font-size:clamp(26px,3vw,38px);font-weight:800;text-transform:uppercase;letter-spacing:-.025em;margin-top:14px;color:var(--dk-ink)}
.dband p{font-size:15.5px;color:var(--dk-soft);font-weight:300;margin-top:14px}
.dual-foot{text-align:center;padding:30px;border-top:1px solid var(--dk-line);font-family:'Archivo',sans-serif;font-weight:600;font-size:15px;letter-spacing:.02em;color:var(--dk-ink)}
.dual-foot em{font-style:normal;color:var(--accent)}
.featured{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.fcard{position:relative;border:2px solid var(--ink);background:var(--card);overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s}
.fcard:hover{transform:translateY(-7px);box-shadow:0 28px 54px rgba(22,20,14,.14)}
.fcard .img{aspect-ratio:4/3.3;overflow:hidden;position:relative;background:var(--paper-2);min-height:220px}
.fcard .img img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .6s var(--ease)}
.fcard:hover .img img{transform:scale(1.05)}
.fcard .ribbon{position:absolute;top:0;left:0;background:var(--accent);color:#fff;font-family:'Archivo',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:7px 13px;z-index:2}
.fcard .b{padding:26px 28px 30px;flex:1;display:flex;flex-direction:column}
.fcard .tag{font-family:'Archivo',sans-serif;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:700}
.fcard h3{font-size:25px;font-weight:800;text-transform:uppercase;letter-spacing:-.02em;margin-top:10px}
.fcard p{font-size:14px;color:var(--soft);font-weight:300;margin-top:11px;line-height:1.55;flex:1}
.fcard .topics{display:flex;gap:6px;flex-wrap:wrap;margin-top:16px}
.fcard .topics span{font-family:'Archivo',sans-serif;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);border:1px solid var(--line);padding:5px 10px;font-weight:500}
.fcard .more2{margin-top:20px;display:inline-flex;align-items:center;gap:8px;font-family:'Archivo',sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.filters{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--line);width:fit-content;margin:0 auto 44px}
.filt{padding:12px 20px;font-family:'Archivo',sans-serif;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--soft);cursor:pointer;transition:all .2s;font-weight:600;border-right:1px solid var(--line)}
.filt:last-child{border-right:none}
.filt:hover{color:var(--ink);background:var(--paper-2)}
.filt.active{background:var(--ink);color:var(--paper)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.card{position:relative;background:var(--paper);overflow:hidden;cursor:pointer;aspect-ratio:3/4}
.card .ph{position:absolute;inset:0;background:var(--paper-2)}
.card .ph img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .6s var(--ease)}
.card:hover .ph img{transform:scale(1.05)}
.card .ph .fb{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Archivo',sans-serif;font-weight:800;font-size:48px;color:rgba(22,20,14,.16)}
.card .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,12,8,.95) 8%,rgba(13,12,8,.34) 46%,transparent 66%)}
.card .meta{position:absolute;left:0;right:0;bottom:0;padding:20px 18px;color:#fff}
.card .tag{display:inline-block;font-family:'Archivo',sans-serif;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--accent);padding:4px 9px;margin-bottom:10px;font-weight:600}
.card .meta h3{font-size:19px;font-weight:800;text-transform:uppercase;color:#fff;line-height:1.05}
.card .meta p{font-size:12px;color:rgba(245,243,236,.84);margin-top:7px;line-height:1.45;font-weight:300;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card .meta .more{margin-top:11px;display:inline-flex;align-items:center;gap:6px;font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:0;transform:translateY(6px);transition:all .3s var(--ease)}
.card:hover .meta .more{opacity:1;transform:none}
.grid-cta{margin-top:44px;text-align:center}
.why{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--dk-line);border:2px solid var(--dk-ink)}
.wcell{background:var(--dk);padding:36px 28px}
.wcell .n{font-family:'Archivo',sans-serif;font-weight:800;font-size:38px;color:var(--accent);line-height:1}
.wcell:nth-child(2) .n{color:var(--teal)}
.wcell:nth-child(3) .n{color:var(--gold)}
.wcell:nth-child(4) .n{color:var(--accent)}
.wcell h4{font-family:'Archivo',sans-serif;font-weight:700;font-size:16px;text-transform:uppercase;color:var(--dk-ink);margin-top:18px}
.wcell p{font-size:14px;color:var(--dk-soft);font-weight:300;margin-top:10px}
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.tcase{background:var(--card);padding:34px 30px;border-top:4px solid var(--accent)}
.tcase:nth-child(2){border-top-color:var(--teal)}
.tcase:nth-child(3){border-top-color:var(--gold)}
.tcase .stars{color:var(--gold);letter-spacing:3px;font-size:14px}
.tcase blockquote{font-family:'Inter',sans-serif;font-size:15.5px;line-height:1.55;font-weight:300;color:var(--ink);margin:16px 0 22px}
.tcase .who{border-top:1px solid var(--line);padding-top:16px}
.tcase .who b{font-family:'Archivo',sans-serif;font-size:13.5px;color:var(--ink);display:block;font-weight:700}
.tcase .who span{font-size:12.5px;color:var(--soft)}
.enq{display:grid;grid-template-columns:1fr 1.05fr;border:2px solid var(--dk-ink)}
.enq-left{padding:52px 44px;background:var(--dk);color:var(--dk-ink);border-right:2px solid var(--dk-ink)}
.enq-left h2{font-size:clamp(28px,3.2vw,44px);font-weight:800;text-transform:uppercase;letter-spacing:-.03em;color:var(--dk-ink);margin-top:14px}
.enq-left h2 em{font-style:normal;color:var(--gold)}
.enq-left .p{color:var(--dk-soft);font-size:16px;margin-top:16px;font-weight:300;max-width:380px}
.enq-contact{margin-top:28px;border-top:1px solid var(--dk-line)}
.enq-contact a{display:flex;gap:13px;align-items:center;padding:13px 0;border-bottom:1px solid var(--dk-line);color:var(--dk-ink);font-family:'Archivo',sans-serif;font-weight:500;font-size:14.5px}
.enq-contact a span{color:var(--gold)}
.enq-right{background:var(--card);padding:44px 38px}
.enq-right h3{font-family:'Archivo',sans-serif;font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:700}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;margin-top:18px}
.fg label{font-family:'Archivo',sans-serif;font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-bottom:8px}
.fg input,.fg textarea{border:none;border-bottom:2px solid var(--line);padding:11px 2px;font-family:'Inter',sans-serif;font-size:15px;color:var(--ink);background:transparent;outline:none;transition:border .25s}
.fg input:focus,.fg textarea:focus{border-color:var(--accent)}
.fg textarea{resize:vertical;min-height:64px}
.ok{display:none;text-align:center;padding:44px 10px}
.ok.show{display:block}
.ok .big{font-family:'Archivo',sans-serif;font-size:24px;font-weight:800;text-transform:uppercase;color:var(--ink);margin-top:14px}
.ok p{color:var(--soft);margin-top:10px}
.check{width:60px;height:60px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto}
@media(max-width:1024px){
  .sph-grid{grid-template-columns:1fr;gap:38px}
  .enq{grid-template-columns:1fr;gap:38px}
  .sph-hero{padding-bottom:50px}
  .sph-fig{max-width:460px;margin:0 auto;width:100%;align-self:stretch;min-height:auto;aspect-ratio:auto;display:flex;flex-direction:column}
  .sph-mosaic{position:relative;inset:auto;aspect-ratio:4/3.8;width:100%}
  .sph-fig .sph-tagline{position:relative;inset:auto;width:100%}
  .grid{grid-template-columns:repeat(2,1fr)}
  .featured{grid-template-columns:1fr 1fr}
  .dual,.vstrip .wrap,.why{grid-template-columns:1fr 1fr}
  .cases{grid-template-columns:1fr}
  .dband{border-right:none;border-bottom:1px solid var(--dk-line)}
  .dband:last-child{border-bottom:none}
  .vitem{border-right:none;border-bottom:1px solid var(--dk-line)}
  .enq-left{border-right:none;border-bottom:2px solid var(--dk-ink)}
}

@media(max-width:768px) {
  .filters {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    width: 100%;
    margin-bottom: 30px;
    border: none;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .filters::-webkit-scrollbar {
    display: none;
  }
  .filt {
    flex: 0 0 auto;
    border: 1px solid var(--line) !important;
    margin-right: 8px;
    border-radius: 4px;
  }
  .filt:last-child {
    margin-right: 0;
  }
}

@media(max-width:680px){
  .grid,.why,.dual,.vstrip .wrap,.featured{grid-template-columns:1fr}
  .sec{padding:60px 0}
  .fr{grid-template-columns:1fr}
  .sph-proofrow{justify-content:center;text-align:center;gap:16px 24px}
  .sph-proof-item{flex:0 1 calc(50% - 12px)}
  .sph-proof-item b{justify-content:center}
  .sph-divider{display:none}
  .vitem:last-child{border-bottom:none}
  .sph-search input{padding:13px 16px;font-size:14.5px}
  .sph-search button{padding:0 18px;font-size:12px}
  .videobox{aspect-ratio:16/9;margin-left:-32px;margin-right:-32px;width:calc(100% + 64px);border-left:none;border-right:none}
  .videobox .circ{width:60px;height:60px}
  .videobox .circ::after{border-width:10px 0 10px 16px;margin-left:4px}
  .sph-hero h1 br {
    display: none;
  }
  .sph-hero h1 {
    font-size: clamp(32px, 8vw, 42px);
  }
  .sph-fig {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
    aspect-ratio: auto;
    align-self: center;
  }
  .sph-hero {
    padding-bottom: 50px;
  }
  /* Ensure featured card images have enough height on single-column mobile */
  .fcard .img {
    min-height: 260px;
    aspect-ratio: auto;
  }
}

@media(max-width:480px){
  .sph-search {
    flex-direction: column;
    border: none;
    background: transparent;
    gap: 10px;
  }
  .sph-search input {
    background: var(--card);
    border: 2px solid var(--ink);
    padding: 15px;
    width: 100%;
    border-radius: 0;
  }
  .sph-search button {
    padding: 15px;
    justify-content: center;
    width: 100%;
    border-radius: 0;
  }
}/* End custom CSS */