:root {
--ink: #0d0d0d;
--coal: #141414;
--iron: #1c1c1c;
--steel: #7a7672;
--mist: #f4f1ea;
--concrete: #e8e4dc;
--paper: #0d0d0d;
--amber: #0077b6;
--amber-deep: #00b4d8;
--teal: #6ea6bb;
--red: #b5423e;
--white: #f4f1ea;
--border: #272727;
--muted: #a49f99;
--shadow: 0 20px 50px rgba(0, 0, 0, 0.42);
--radius: 8px;
--container: 1180px;
}
* {
box-sizing: border-box;
}
html {
scroll-behavior: smooth;
}
body {
margin: 0;
background: var(--paper);
color: var(--concrete);
font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
font-size: 16px;
line-height: 1.6;
}
img,
svg {
display: block;
max-width: 100%;
}
a {
color: inherit;
text-decoration: none;
}
button,
input,
textarea,
select {
font: inherit;
}
button {
cursor: pointer;
}
.skip-link {
background: var(--amber);
color: var(--ink);
left: 1rem;
padding: 0.75rem 1rem;
position: fixed;
top: -100px;
z-index: 1000;
}
.skip-link:focus {
top: 1rem;
}
.site-header {
background: rgba(13, 13, 13, 0.9);
border-bottom: 1px solid rgba(255, 255, 255, 0.1);
color: var(--white);
left: 0;
position: sticky;
right: 0;
top: 0;
z-index: 50;
backdrop-filter: blur(18px);
}
.nav-shell,
.section-inner,
.footer-inner {
margin: 0 auto;
max-width: var(--container);
padding-left: 1.5rem;
padding-right: 1.5rem;
}
.nav-shell {
align-items: center;
display: flex;
gap: 1.25rem;
justify-content: space-between;
min-height: 76px;
}
.brand {
align-items: center;
display: inline-flex;
flex: 0 0 auto;
gap: 0.8rem;
font-weight: 800;
}
.brand-mark {
align-items: center;
background: #05090b;
border: 1px solid rgba(0, 180, 216, 0.58);
border-radius: 12px;
box-shadow: 0 0 18px rgba(0, 180, 216, 0.2);
display: inline-flex;
height: 52px;
justify-content: center;
overflow: hidden;
padding: 0;
width: 52px;
}
.brand-mark img {
height: 100%;
object-fit: cover;
transform: scale(1.14);
width: 100%;
}
.brand-copy {
display: grid;
line-height: 1.1;
max-width: 18rem;
}
.brand-copy strong {
font-size: 1rem;
}
.brand-copy span {
color: var(--concrete);
font-size: 0.72rem;
font-weight: 600;
}
.brand-copy .brand-slogan {
color: var(--sky);
font-size: 0.66rem;
margin-top: 0.16rem;
}
.nav-toggle {
align-items: center;
background: transparent;
border: 1px solid rgba(255, 255, 255, 0.2);
border-radius: 8px;
color: var(--white);
display: none;
height: 44px;
justify-content: center;
width: 44px;
}
.nav-toggle span,
.nav-toggle span::before,
.nav-toggle span::after {
background: currentColor;
content: "";
display: block;
height: 2px;
position: relative;
transition: transform 180ms ease, top 180ms ease, opacity 180ms ease;
width: 20px;
}
.nav-toggle span::before {
position: absolute;
top: -7px;
}
.nav-toggle span::after {
position: absolute;
top: 7px;
}
.nav-toggle[aria-expanded="true"] span {
background: transparent;
}
.nav-toggle[aria-expanded="true"] span::before {
top: 0;
transform: rotate(45deg);
}
.nav-toggle[aria-expanded="true"] span::after {
top: 0;
transform: rotate(-45deg);
}
.site-nav {
align-items: center;
display: flex;
gap: 0.25rem;
}
.site-nav a {
border-radius: 8px;
color: rgba(255, 255, 255, 0.82);
font-size: 0.95rem;
font-weight: 650;
padding: 0.65rem 0.8rem;
}
.site-nav a:hover,
.site-nav a:focus,
.site-nav a.is-active {
background: rgba(255, 255, 255, 0.1);
color: var(--white);
}
.nav-cta {
background: var(--amber) !important;
color: var(--white) !important;
}
.hero {
background: var(--ink);
color: var(--white);
min-height: 720px;
overflow: hidden;
position: relative;
}
.hero-bg-img {
height: 100%;
inset: 0;
object-fit: cover;
position: absolute;
width: 100%;
z-index: 0;
}
.hero::before {
background: linear-gradient(90deg, rgba(13, 13, 13, 0.94) 0%, rgba(13, 13, 13, 0.76) 45%, rgba(13, 13, 13, 0.28) 100%);
content: "";
inset: 0;
position: absolute;
z-index: 1;
}
.hero::after {
background: linear-gradient(0deg, var(--paper) 0, rgba(247, 248, 246, 0) 84px);
bottom: 0;
content: "";
height: 160px;
left: 0;
position: absolute;
right: 0;
z-index: 2;
}
.hero .section-inner {
align-items: center;
display: grid;
grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.55fr);
min-height: 720px;
position: relative;
z-index: 3;
}
.eyebrow {
align-items: center;
color: var(--amber);
display: inline-flex;
font-weight: 800;
gap: 0.65rem;
margin: 0 0 1rem;
}
.eyebrow::before {
background: var(--amber);
content: "";
display: inline-block;
height: 2px;
width: 42px;
}
h1,
h2,
h3,
p {
margin-top: 0;
}
h1 {
font-family: Georgia, "Times New Roman", serif;
font-size: 4.8rem;
font-weight: 400;
line-height: 0.98;
margin-bottom: 1.25rem;
max-width: 810px;
}
h2 {
color: var(--white);
font-family: Georgia, "Times New Roman", serif;
font-size: 2.65rem;
font-weight: 400;
line-height: 1.08;
margin-bottom: 1rem;
}
h3 {
font-size: 1.25rem;
line-height: 1.25;
margin-bottom: 0.75rem;
}
.lead {
color: rgba(255, 255, 255, 0.78);
font-size: 1.2rem;
max-width: 670px;
}
.text-lead {
color: var(--muted);
font-size: 1.1rem;
max-width: 720px;
}
.hero-actions,
.section-actions {
display: flex;
flex-wrap: wrap;
gap: 0.85rem;
margin-top: 1.75rem;
}
.button {
align-items: center;
border: 1px solid transparent;
border-radius: 8px;
display: inline-flex;
font-weight: 800;
gap: 0.55rem;
justify-content: center;
min-height: 48px;
padding: 0.78rem 1rem;
text-align: center;
transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}
.button:hover,
.button:focus {
transform: translateY(-2px);
}
.button-primary {
background: var(--amber);
color: var(--white);
}
.button-secondary {
background: rgba(255, 255, 255, 0.08);
border-color: rgba(255, 255, 255, 0.24);
color: var(--white);
}
.button-dark {
background: var(--amber);
color: var(--white);
}
.button-light {
background: transparent;
border-color: rgba(244, 241, 234, 0.28);
color: var(--white);
}
.trust-panel {
align-self: end;
background: rgba(15, 18, 19, 0.82);
border: 1px solid rgba(255, 255, 255, 0.16);
border-radius: 8px;
box-shadow: var(--shadow);
color: var(--white);
margin-bottom: 4.5rem;
padding: 1.25rem;
}
.trust-panel strong {
display: block;
font-size: 1.25rem;
}
.trust-panel p {
color: rgba(255, 255, 255, 0.72);
margin-bottom: 0;
}
.trust-grid {
display: grid;
gap: 0.8rem;
grid-template-columns: repeat(2, minmax(0, 1fr));
margin-top: 1rem;
}
.trust-item {
border-top: 1px solid rgba(255, 255, 255, 0.12);
padding-top: 0.8rem;
}
.trust-item span {
color: var(--amber);
display: block;
font-size: 1.65rem;
font-weight: 850;
line-height: 1;
}
.section {
padding: 6rem 0;
}
.section-compact {
padding: 4.5rem 0;
}
.section-dark {
background: var(--ink);
color: var(--white);
}
.section-dark .text-lead,
.section-dark .muted,
.section-dark p {
color: rgba(255, 255, 255, 0.7);
}
.section-steel {
background: var(--coal);
}
.section-header {
align-items: end;
display: grid;
gap: 1.5rem;
grid-template-columns: minmax(0, 0.9fr) minmax(260px, 0.42fr);
margin-bottom: 2.5rem;
}
.section-header-spaced {
margin-top: 4rem;
}
.section-kicker {
color: var(--amber-deep);
font-weight: 850;
margin-bottom: 0.5rem;
}
.grid {
display: grid;
gap: 1.25rem;
}
.grid-2 {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-3 {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid-4 {
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.feature-card,
.service-card,
.project-card,
.stat-card,
.safety-card,
.quote-card,
.value-card {
background: var(--coal);
border: 1px solid var(--border);
border-radius: 8px;
box-shadow: 0 14px 30px rgba(0, 0, 0, 0.18);
color: var(--white);
}
.feature-card,
.service-card,
.stat-card,
.safety-card,
.quote-card,
.value-card {
padding: 1.25rem;
}
.feature-card .icon,
.service-card .icon,
.safety-card .icon,
.value-card .icon {
align-items: center;
background: rgba(0, 180, 216, 0.14);
border-radius: 8px;
color: var(--amber-deep);
display: inline-flex;
height: 44px;
justify-content: center;
margin-bottom: 1rem;
width: 44px;
}
.feature-card p,
.service-card p,
.project-card p,
.safety-card p,
.quote-card p,
.value-card p {
color: var(--muted);
}
.stat-card {
background: var(--coal);
color: var(--white);
min-height: 150px;
}
.stat-card span {
color: var(--amber);
display: block;
font-size: 2.6rem;
font-weight: 850;
line-height: 1;
margin-bottom: 0.45rem;
}
.stat-card p {
color: rgba(255, 255, 255, 0.7);
margin-bottom: 0;
}
.project-card {
overflow: hidden;
}
.project-card img {
aspect-ratio: 1.45 / 1;
object-fit: cover;
width: 100%;
}
.project-body {
padding: 1.2rem;
}
.project-meta {
align-items: center;
color: var(--amber-deep);
display: flex;
flex-wrap: wrap;
font-size: 0.9rem;
font-weight: 800;
gap: 0.5rem;
margin-bottom: 0.65rem;
}
.tag {
background: rgba(0, 180, 216, 0.12);
border-radius: 999px;
color: var(--amber-deep);
display: inline-flex;
font-size: 0.85rem;
font-weight: 800;
padding: 0.3rem 0.6rem;
}
.split {
align-items: center;
display: grid;
gap: 3rem;
grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.7fr);
}
.image-panel {
border-radius: 8px;
min-height: 460px;
overflow: hidden;
position: relative;
}
.image-panel img {
height: 100%;
object-fit: cover;
position: absolute;
width: 100%;
}
.image-panel::after {
background: linear-gradient(0deg, rgba(11, 13, 14, 0.62), rgba(11, 13, 14, 0.02));
content: "";
inset: 0;
position: absolute;
}
.check-list {
display: grid;
gap: 0.75rem;
list-style: none;
margin: 1.5rem 0 0;
padding: 0;
}
.check-list li {
align-items: start;
display: grid;
gap: 0.7rem;
grid-template-columns: 26px minmax(0, 1fr);
}
.check-list li::before {
background: var(--amber);
border-radius: 8px;
content: "";
height: 10px;
margin-top: 0.5rem;
width: 10px;
}
.page-hero {
background: var(--ink);
color: var(--white);
overflow: hidden;
padding: 6.5rem 0 5rem;
position: relative;
}
.page-hero::before {
background:
linear-gradient(90deg, rgba(13, 13, 13, 0.97), rgba(13, 13, 13, 0.78)),
url(//lexxconstruction.com.au/wp-content/themes/lexx-construction-hard-route-20260529-170314/assets/img/main/home-hero-office.png) center / cover no-repeat;
content: "";
inset: 0;
opacity: 0.78;
position: absolute;
}
.page-hero .section-inner {
position: relative;
}
.page-hero h1 {
font-size: 3.7rem;
max-width: 850px;
}
.breadcrumb {
color: rgba(255, 255, 255, 0.64);
font-size: 0.92rem;
margin-bottom: 1rem;
}
.breadcrumb a {
color: var(--white);
font-weight: 800;
}
.process {
counter-reset: step;
}
.process .feature-card {
position: relative;
}
.process .feature-card::before {
background: var(--ink);
border-radius: 8px;
color: var(--white);
content: counter(step, decimal-leading-zero);
counter-increment: step;
display: inline-flex;
font-weight: 850;
margin-bottom: 1.2rem;
padding: 0.35rem 0.55rem;
}
.capacity-strip {
background: var(--ink);
color: var(--white);
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.capacity-strip div {
border-right: 1px solid rgba(255, 255, 255, 0.12);
padding: 1.4rem;
}
.capacity-strip div:last-child {
border-right: 0;
}
.capacity-strip strong {
color: var(--amber);
display: block;
font-size: 2rem;
line-height: 1;
}
.gallery-tools {
display: flex;
flex-wrap: wrap;
gap: 0.65rem;
margin-bottom: 1.5rem;
}
.filter-button {
background: var(--coal);
border: 1px solid var(--border);
border-radius: 999px;
color: var(--white);
font-weight: 800;
min-height: 42px;
padding: 0.5rem 0.8rem;
}
.filter-button.is-active {
background: var(--amber);
color: var(--white);
}
.photo-grid {
display: grid;
gap: 1rem;
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.photo-tile {
background: var(--coal);
border: 1px solid var(--border);
border-radius: 8px;
color: var(--white);
overflow: hidden;
}
.photo-tile img {
aspect-ratio: 1.25 / 1;
object-fit: cover;
width: 100%;
}
.photo-tile span {
color: var(--muted);
display: block;
font-size: 0.9rem;
font-weight: 750;
padding: 0.75rem 0.85rem;
}
.contact-layout {
align-items: start;
display: grid;
gap: 2rem;
grid-template-columns: minmax(0, 0.72fr) minmax(320px, 0.45fr);
}
.contact-form {
background: var(--coal);
border: 1px solid var(--border);
border-radius: 8px;
box-shadow: var(--shadow);
padding: 1.25rem;
}
.form-grid {
display: grid;
gap: 1rem;
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.field {
display: grid;
gap: 0.4rem;
}
.field.full {
grid-column: 1 / -1;
}
.field label {
font-weight: 800;
}
.field input,
.field textarea,
.field select {
background: var(--ink);
border: 1px solid var(--border);
border-radius: 8px;
color: var(--white);
min-height: 48px;
padding: 0.72rem 0.8rem;
width: 100%;
}
.field textarea {
min-height: 160px;
resize: vertical;
}
.field input:focus,
.field textarea:focus,
.field select:focus {
border-color: var(--amber-deep);
outline: 3px solid rgba(243, 180, 63, 0.22);
}
.form-status {
border-radius: 8px;
display: none;
font-weight: 800;
margin-top: 1rem;
padding: 0.85rem;
}
.form-status.is-visible {
background: rgba(0, 180, 216, 0.12);
color: var(--amber-deep);
display: block;
}
.contact-details {
display: grid;
gap: 1rem;
}
.detail-card {
background: var(--coal);
border: 1px solid var(--border);
border-radius: 8px;
color: var(--white);
padding: 1.25rem;
}
.detail-card span {
color: var(--amber);
display: block;
font-weight: 850;
margin-bottom: 0.35rem;
}
.detail-card p {
color: rgba(255, 255, 255, 0.72);
margin-bottom: 0;
}
.cta-band {
background: var(--ink);
color: var(--white);
overflow: hidden;
position: relative;
}
.cta-band::before {
background:
linear-gradient(90deg, rgba(13, 13, 13, 0.92), rgba(13, 13, 13, 0.72)),
url(//lexxconstruction.com.au/wp-content/themes/lexx-construction-hard-route-20260529-170314/assets/img/main/cta-team.png) center / cover no-repeat;
content: "";
inset: 0;
position: absolute;
}
.cta-band .section-inner {
align-items: center;
display: grid;
gap: 1.5rem;
grid-template-columns: minmax(0, 0.85fr) minmax(260px, 0.35fr);
position: relative;
}
.cta-band p {
color: rgba(255, 255, 255, 0.72);
margin-bottom: 0;
}
.site-footer {
background: #090a0b;
color: var(--white);
padding: 3.5rem 0 2rem;
}
.footer-inner {
display: grid;
gap: 2rem;
}
.footer-top {
display: grid;
gap: 2rem;
grid-template-columns: minmax(0, 0.75fr) repeat(3, minmax(150px, 0.25fr));
}
.footer-top p,
.footer-bottom {
color: rgba(255, 255, 255, 0.64);
}
.footer-links {
display: grid;
gap: 0.6rem;
}
.footer-links strong {
color: var(--white);
}
.footer-links a {
color: rgba(255, 255, 255, 0.68);
}
.footer-links a:hover,
.footer-links a:focus {
color: var(--amber);
}
.footer-bottom {
border-top: 1px solid rgba(255, 255, 255, 0.12);
display: flex;
flex-wrap: wrap;
gap: 1rem;
justify-content: space-between;
padding-top: 1.25rem;
}
.reveal {
opacity: 0;
transform: translateY(24px);
transition: opacity 600ms ease, transform 600ms ease;
}
.reveal.is-visible {
opacity: 1;
transform: translateY(0);
}
.hero-copy {
animation: heroIn 740ms ease both;
}
.trust-panel {
animation: heroIn 880ms ease 120ms both;
}
@keyframes heroIn {
from {
opacity: 0;
transform: translateY(22px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@media (max-width: 980px) {
h1 {
font-size: 3.5rem;
}
h2 {
font-size: 2.25rem;
}
.hero,
.hero .section-inner {
min-height: auto;
}
.hero .section-inner {
gap: 2rem;
grid-template-columns: 1fr;
padding-bottom: 7rem;
padding-top: 6rem;
}
.trust-panel {
margin-bottom: 0;
max-width: 540px;
}
.section-header,
.split,
.contact-layout,
.cta-band .section-inner {
grid-template-columns: 1fr;
}
.grid-4 {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid-3 {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.photo-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.capacity-strip {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
@media (max-width: 780px) {
.nav-toggle {
display: inline-flex;
}
.site-nav {
background: var(--ink);
border-top: 1px solid rgba(255, 255, 255, 0.1);
display: none;
flex-direction: column;
gap: 0.25rem;
left: 0;
padding: 0.75rem 1.5rem 1.25rem;
position: absolute;
right: 0;
top: 76px;
}
.site-nav.is-open {
display: flex;
}
.site-nav a {
width: 100%;
}
.nav-cta {
justify-content: center;
}
.brand-copy span {
display: none;
}
.section {
padding: 4rem 0;
}
.page-hero {
padding: 4.5rem 0 3.8rem;
}
.page-hero h1 {
font-size: 3rem;
}
.form-grid,
.grid-2,
.grid-3,
.grid-4,
.photo-grid {
grid-template-columns: 1fr;
}
.footer-top {
grid-template-columns: 1fr;
}
}
@media (max-width: 560px) {
body {
font-size: 15px;
}
.nav-shell,
.section-inner,
.footer-inner {
padding-left: 1rem;
padding-right: 1rem;
}
h1 {
font-size: 2.75rem;
}
h2 {
font-size: 2rem;
}
.page-hero h1 {
font-size: 2.45rem;
}
.lead {
font-size: 1.05rem;
}
.hero-actions,
.section-actions {
flex-direction: column;
}
.button {
width: 100%;
}
.trust-grid,
.capacity-strip {
grid-template-columns: 1fr;
}
.capacity-strip div {
border-bottom: 1px solid rgba(255, 255, 255, 0.12);
border-right: 0;
}
.image-panel {
min-height: 320px;
}
}
@media (prefers-reduced-motion: reduce) {
*,
*::before,
*::after {
animation-duration: 0.001ms !important;
scroll-behavior: auto !important;
transition-duration: 0.001ms !important;
}
.reveal {
opacity: 1;
transform: none;
}
}