@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:ital,wght@0,300;0,600;1,300;1,600&display=swap');
:root{--bg:#4d4d4d;--bg2:#525252;--bg3:#575757;--hdr:#3d3d3d;--text:#ffffff;--muted:rgba(255,255,255,.65);--faint:rgba(255,255,255,.15);--border:rgba(212,212,255,.1);--accent:#877878;--accent2:#5a5858;--tan:#e7b788;--t1:#5f5454;--t2:#877878;--t3:#777171;--t4:#c8a068;--t5:#6a8fc8;--t6:#6aaa88}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Source Sans 3','Source Sans Pro',sans-serif;font-weight:300;color:var(--text);background:var(--bg);line-height:1.65;font-size:17px;padding-top:3.25em}
a{color:inherit;text-decoration:none;transition:color .2s}
a:hover{color:var(--tan)}
img{max-width:100%;display:block}
h1,h2,h3,h4,h5{font-weight:600;line-height:1.35}
p{margin:0 0 1.5em}
p:last-child{margin-bottom:0}
.container{max-width:65em;margin:0 auto;padding:0 3em}

/* HEADER */
#header{position:fixed;top:0;left:0;right:0;z-index:1000;height:3.25em;background:var(--hdr);box-shadow:0 0 .25em rgba(0,0,0,.25);display:flex;align-items:center}
.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 2em}
.logo a{display:inline-flex;align-items:center;gap:.5em;font-size:.8em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--text);text-decoration:none}
.logo a:hover{color:var(--text)}
.logo-img{height:28px;width:28px;object-fit:contain;filter:invert(1) brightness(1.8)}
.logo strong{display:inline-block;background:#fff;color:var(--bg);padding:0 .4em;margin-right:.35em;font-weight:600;transition:background .2s}
.logo a:hover strong{background:var(--accent)}
.nav-links{display:flex;align-items:center;gap:0}
.nav-links a{font-size:.8em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;padding:0 .85em;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-cta{font-size:.75em!important;box-shadow:inset 0 0 0 2px var(--text);padding:0 1.1em!important;height:2.4em;line-height:2.4em;display:inline-flex!important;align-items:center;margin-left:.4em;transition:box-shadow .2s,color .2s!important;color:var(--text)!important}
.nav-cta:hover{box-shadow:inset 0 0 0 2px var(--accent)!important;color:var(--accent)!important}
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.3rem;cursor:pointer}

/* BUTTONS */
.btn{display:inline-block;box-shadow:inset 0 0 0 2px #fff;background:transparent;color:#fff;font-size:.8em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;height:3.5em;line-height:3.5em;padding:0 1.75em;cursor:pointer;transition:box-shadow .2s,color .2s,background .2s}
.btn:hover{box-shadow:inset 0 0 0 2px var(--accent);color:var(--accent)}
.btn.special{box-shadow:none;background:#fff;color:var(--bg);height:3.5em;line-height:3.5em}
.btn.special:hover{background:var(--accent);color:#fff}

/* BANNER */
#banner{position:relative;min-height:60vh;max-height:32em;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:linear-gradient(rgba(60,55,50,.88),rgba(40,35,30,.92)),repeating-linear-gradient(110deg,#3a3530 0,#3a3530 3px,#423d38 3px,#423d38 90px)}
#banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(200,160,100,.08) 0%,transparent 70%),radial-gradient(ellipse at 70% 50%,rgba(100,130,180,.06) 0%,transparent 60%)}
.banner-inner{position:relative;padding:5em 2em;width:100%}
.banner-logo{height:80px;width:80px;object-fit:contain;filter:invert(1) brightness(1.8);margin:0 auto .85em}
.banner-tag{font-size:.7em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--tan);margin-bottom:1em;display:block}
#banner h1{font-size:3.25em;font-weight:600;line-height:1.1;margin-bottom:.5em}
#banner h1 span{color:var(--tan)}
#banner p{font-size:1.05em;color:var(--muted);max-width:38em;margin:0 auto 2em}
.banner-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* PAGE BANNER */
.page-banner{position:relative;min-height:18em;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:linear-gradient(rgba(50,45,40,.9),rgba(35,30,25,.95)),repeating-linear-gradient(110deg,#3a3530 0,#3a3530 2px,#423d38 2px,#423d38 70px)}
.page-banner-inner{position:relative;padding:4em 2em}
.page-banner h1{font-size:2.25em;font-weight:600}
.page-banner p{color:var(--muted);font-size:1rem;margin-top:.5em}

/* TILES */
#tiles{display:flex;flex-wrap:wrap}
.tile{position:relative;width:40%;height:40vh;min-height:23em;max-height:40em;display:flex;align-items:flex-end;overflow:hidden;cursor:pointer}
.tile:nth-child(even){width:60%}
.tile-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.tile:hover .tile-bg{transform:scale(1.05)}
.tile::before{content:'';position:absolute;inset:0;z-index:1;background:var(--ov,#2a2520);opacity:.42;transition:opacity .4s}
.tile:hover::before{opacity:.15}
.tile::after{content:'';position:absolute;inset:0;z-index:2;background:rgba(40,38,36,.18)}
.tile-bg-1{background:linear-gradient(160deg,#2a2520 0%,#3d3530 40%,#252018 100%)}
.tile-bg-2{background:linear-gradient(140deg,#1e2818 0%,#2d3e22 45%,#18220e 100%)}
.tile-bg-3{background:linear-gradient(155deg,#252018 0%,#3a3025 50%,#1e1a10 100%)}
.tile-bg-4{background:linear-gradient(145deg,#0e1825 0%,#1e2e42 50%,#0a1018 100%)}
.tile-bg-5{background:linear-gradient(165deg,#201818 0%,#352020 50%,#180e0e 100%)}
.tile-bg-6{background:linear-gradient(150deg,#18181e 0%,#252535 50%,#10101a 100%)}
.tile-content{position:relative;z-index:3;padding:2em 2.5em;width:100%;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 100%);transition:padding .3s}
.tile:hover .tile-content{padding-bottom:2.75em}
.tile-tag{display:block;font-size:.65em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:.35em}
.tile-content h3{font-size:1.35em;font-weight:600;color:#fff;line-height:1.2;margin:0}
.tile-arrow{display:inline-block;margin-top:.5em;font-size:.75em;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.7);opacity:0;transition:opacity .3s}
.tile:hover .tile-arrow{opacity:1;color:var(--tan)}

/* SPOTLIGHT */
.spotlight{display:flex;align-items:stretch;min-height:22em;border-top:1px solid var(--border)}
.spotlight.alt{flex-direction:row-reverse;background:var(--bg2)}
.spotlight-img{flex:0 0 38%;min-height:22em;position:relative;overflow:hidden}
.spot-img-inner{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.spotlight:hover .spot-img-inner{transform:scale(1.04)}
.spot-bg-1{background:linear-gradient(135deg,#2d2520 0%,#4a3d32 50%,#1e1810 100%)}
.spot-bg-2{background:linear-gradient(135deg,#0e2010 0%,#1e3820 50%,#0a1808 100%)}
.spot-bg-3{background:linear-gradient(135deg,#0e1828 0%,#1e3048 50%,#080e18 100%)}
.spot-bg-4{background:linear-gradient(135deg,#1e1010 0%,#302020 50%,#100808 100%)}
.spotlight-body{flex:1;padding:4em 3em;display:flex;flex-direction:column;justify-content:center}
.spot-lbl{font-size:.7em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--tan);margin-bottom:.75em;display:block}
.spotlight-body h2{font-size:1.75em;font-weight:600;margin-bottom:.75em;position:relative}
.spotlight-body h2::after{content:'';display:block;width:100%;height:2px;background:rgba(255,255,255,.15);margin:.5em 0 0}
.spotlight-body p{color:var(--muted);font-size:.95em;margin-bottom:1.25em}

/* INNER SECTIONS */
.inner{padding:5em 0 3em;border-top:1px solid var(--border)}
.inner.alt{background:var(--bg3)}
.sec-head{text-align:center;margin-bottom:3em}
.sec-lbl{display:block;font-size:.7em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--tan);margin-bottom:.6em}
.sec-head h2{font-size:1.75em;font-weight:600;position:relative;display:inline-block}
.sec-head h2::after{content:'';display:block;height:2px;background:#fff;margin:.325em auto .5em;width:80%}
.sec-head p{color:var(--muted);max-width:36em;margin:.5em auto 0}

/* FEATURES */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:2em}
.feature{text-align:center;padding:1.25em;border:1px solid var(--border);transition:background .2s}
.feature:hover{background:rgba(255,255,255,.04)}
.feature-icon{font-size:2.5em;margin-bottom:.5em}
.feature h3{font-size:1.05em;font-weight:600;margin-bottom:.5em}
.feature p{font-size:.87em;color:var(--muted);line-height:1.65;margin:0}

/* SINGLE SERVICE/PROJECT */
.single-section{padding:0}
.single-content{padding:4em 0}
.single-content .prose h2{font-size:1.4em;font-weight:600;margin:2em 0 .6em;position:relative}
.single-content .prose h2::after{content:'';display:block;height:2px;background:rgba(255,255,255,.12);margin:.35em 0 0}
.single-content .prose p{color:var(--muted);margin-bottom:1em}
.single-content .prose ul,.single-content .prose ol{padding-left:1.5em;margin-bottom:1em}
.single-content .prose li{color:var(--muted);margin-bottom:.35em}
.cta-block{margin-top:3em;padding:2em;border:1px solid var(--border);background:rgba(255,255,255,.04)}
.cta-block p{font-weight:600;margin-bottom:1em;color:var(--text)}

/* CONTACT */
#contact{padding:5em 0 3em;border-top:1px solid var(--border);background:var(--bg2)}
.contact-split{display:grid;grid-template-columns:1.5fr 1fr;gap:4em}
.contact-split h2{font-size:1.75em;font-weight:600;margin-bottom:.75em;position:relative}
.contact-split h2::after{content:'';display:block;height:2px;background:rgba(255,255,255,.15);margin:.4em 0 .75em}
.form-field{margin-bottom:1.25em}
.form-field label{display:block;font-size:.8em;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--text);margin-bottom:.4em}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:1.25em}
.form-field input,.form-field textarea,.form-field select{width:100%;background:rgba(212,212,255,.04);border:1px solid var(--border);color:#fff;font-family:inherit;font-size:.9em;font-weight:300;padding:0 1em;height:2.75em;outline:none;transition:border-color .2s}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{border-color:var(--accent)}
.form-field textarea{height:8em;padding:.75em 1em;resize:vertical}
.form-field select option{background:var(--bg)}
.form-field input::placeholder,.form-field textarea::placeholder{color:rgba(255,255,255,.25)}
.ci-side h3{font-size:1.1em;font-weight:600;margin-bottom:1.25em;position:relative}
.ci-side h3::after{content:'';display:block;height:2px;background:rgba(255,255,255,.12);margin:.4em 0 0}
.ci-item{display:flex;align-items:flex-start;gap:.85em;margin-bottom:1.25em}
.ci-icon{font-size:1.4em;flex-shrink:0;margin-top:.05em}
.ci-lbl{font-size:.72em;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:.15em}
.ci-val{font-size:.9em;color:var(--muted)}
.ci-val a{color:var(--muted)}
.ci-val a:hover{color:#fff}
.vet-block{margin-top:2em;padding:1.25em;border:1px solid var(--border);text-align:center}
.vet-block p{font-size:.8em;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--tan);margin:0}

/* FOOTER */
#footer{padding:2em 0;border-top:1px solid var(--border);background:var(--hdr);text-align:center}
.footer-logo-img{height:50px;width:50px;object-fit:contain;filter:invert(1) brightness(1.8);margin:0 auto .75em;opacity:.6}
.footer-links{list-style:none;display:flex;justify-content:center;flex-wrap:wrap;gap:0;margin-bottom:.75em;padding:0}
.footer-links li{font-size:.8em;color:rgba(255,255,255,.25);padding:0 .9em;border-left:1px solid var(--border)}
.footer-links li:first-child{border-left:none}
.footer-links a{color:rgba(255,255,255,.4);transition:color .2s}
.footer-links a:hover{color:#fff}
.footer-copy{font-size:.75em;color:rgba(255,255,255,.2)}
.footer-copy a{color:rgba(255,255,255,.3)}

/* RESPONSIVE */
@media(max-width:980px){.tile{width:50%!important}.features{grid-template-columns:1fr 1fr}.contact-split{grid-template-columns:1fr}.spotlight,.spotlight.alt{flex-direction:column}.spotlight-img{min-height:14em;flex:none}}
@media(max-width:640px){#banner h1{font-size:2em}.container{padding:0 1.5em}.tile{width:100%!important;height:16em;min-height:0}.features{grid-template-columns:1fr}.form-2col{grid-template-columns:1fr}.nav-links{display:none}.nav-links.open{display:flex;flex-direction:column;position:absolute;top:3.25em;left:0;right:0;background:var(--hdr);padding:1em;gap:.5em;z-index:200}.nav-toggle{display:block}}

/* tile overlay nth-child colors */
.tile:nth-child(1)::before{background:var(--t1)}
.tile:nth-child(2)::before{background:var(--t2)}
.tile:nth-child(3)::before{background:var(--t3)}
.tile:nth-child(4)::before{background:var(--t4)}
.tile:nth-child(5)::before{background:var(--t5)}
.tile:nth-child(6)::before{background:var(--t6)}
.tile:nth-child(7)::before{background:var(--t1)}
.tile:nth-child(8)::before{background:var(--t2)}
