/* ============================================================
   M/s S. S. Alur Construction Company — corporate stylesheet
   Brand: golden yellow #f7c01e on white / near-black
   ============================================================ */
:root{
  --brand:#f7c01e;
  --brand-deep:#d9a500;
  --brand-soft:#fdf6e0;
  --ink:#161513;
  --body:#3a3833;
  --muted:#6d6a62;
  --line:#e7e4dc;
  --off:#faf9f6;
  --white:#ffffff;
  --maxw:1120px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{font-family:'Barlow',system-ui,sans-serif;color:var(--body);background:var(--white);line-height:1.7;font-size:16.5px}
h1,h2,h3,h4{font-family:'Barlow Condensed',sans-serif;color:var(--ink);line-height:1.08;text-transform:uppercase;letter-spacing:.015em}
.mono{font-family:'IBM Plex Mono',monospace;font-size:.78rem;letter-spacing:.05em}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:84px 0}
section.tight{padding:56px 0}
section.alt{background:var(--off)}
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
h2{font-size:clamp(1.9rem,4vw,2.7rem);font-weight:700;margin-bottom:20px;max-width:760px}
h2::after{content:"";display:block;width:56px;height:4px;background:var(--brand);margin-top:16px;transform-origin:left;transform:scaleX(1)}
h2.uline::after{transform:scaleX(0);transition:transform .8s cubic-bezier(.22,.8,.3,1) .15s}
h2.uline.drawn::after{transform:scaleX(1)}
h3{font-size:1.35rem;font-weight:600;margin-bottom:12px}
.lede{font-size:1.08rem;color:var(--muted);max-width:720px}
p + p{margin-top:14px}
.btn{display:inline-block;text-decoration:none;font-weight:700;font-size:.92rem;padding:13px 28px;border-radius:2px;letter-spacing:.02em;transition:background .15s ease,color .15s ease,border-color .15s ease}
.btn-primary{background:var(--brand);color:var(--ink)}
.btn-primary:hover{background:var(--brand-deep)}
.btn-outline{border:1.5px solid var(--ink);color:var(--ink)}
.btn-outline:hover{border-color:var(--brand-deep);color:var(--brand-deep)}
.btn-inverse{border:1.5px solid #514e46;color:#fff}
.btn-inverse:hover{border-color:var(--brand);color:var(--brand)}
a:focus-visible,button:focus-visible{outline:2px solid var(--brand-deep);outline-offset:3px}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:82px;gap:16px}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.logo img{height:44px;width:auto}
nav ul{display:flex;gap:0;list-style:none;align-items:center;flex-wrap:nowrap}
nav a{text-decoration:none;font-size:.84rem;font-weight:600;color:var(--ink);letter-spacing:.02em;padding:8px 9px;border-bottom:3px solid transparent;white-space:nowrap;display:inline-block}
nav a:hover{color:var(--brand-deep)}
nav a[aria-current="page"]{border-bottom-color:var(--brand)}
.nav-cta{background:var(--ink);color:#fff!important;border-radius:2px;padding:9px 16px;margin-left:10px;border-bottom:none!important;line-height:1}
.nav-cta:hover{background:#000;color:var(--brand)!important}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:3px;padding:8px 14px;font:inherit;font-weight:600;cursor:pointer;color:var(--ink)}
@media(max-width:1240px){
  nav a{font-size:.8rem;padding:8px 7px}
  .logo img{height:40px}
}
@media(max-width:1080px){
  nav ul{display:none;position:absolute;top:82px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:8px 24px 20px;border-bottom:1px solid var(--line)}
  nav ul.open{display:flex}
  nav ul li{border-bottom:1px solid var(--line)}
  nav ul li:last-child{border-bottom:0;padding-top:12px}
  nav ul a{display:block;padding:14px 4px;border-bottom:none}
  nav ul a[aria-current="page"]{color:var(--brand-deep)}
  .menu-btn{display:block}
}

/* ---------- page hero (interior pages) ---------- */
.page-hero{background:var(--ink);color:#fff;padding:76px 0 64px;position:relative}
.page-hero .eyebrow{color:var(--brand)}
.page-hero h1{color:#fff;font-size:clamp(2.4rem,6vw,4rem);font-weight:700;max-width:820px}
.page-hero p{color:#b8b4aa;max-width:660px;margin-top:16px;font-size:1.08rem}
.page-hero .crumb{font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:#8b877d;margin-bottom:26px}
.page-hero .crumb a{color:#8b877d;text-decoration:none}
.page-hero .crumb a:hover{color:var(--brand)}
.page-hero .crumb b{color:var(--brand);font-weight:500}
.centerline{height:5px;width:100%;background:repeating-linear-gradient(90deg,var(--brand) 0 44px,transparent 44px 74px)}

/* ---------- home hero ---------- */
.home-hero{background:var(--ink);color:#fff;padding:110px 0 0;overflow:hidden;position:relative}
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slides .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.6s ease}
.hero-slides .slide.on{opacity:1;animation:heroZoom 9s ease forwards}
@keyframes heroZoom{from{transform:scale(1.07)}to{transform:scale(1.0)}}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(100deg,rgba(22,20,18,.92) 0%,rgba(22,20,18,.72) 42%,rgba(22,20,18,.28) 72%,rgba(22,20,18,.12) 100%)}
.home-hero h1,.home-hero p,.home-hero .eyebrow{text-shadow:0 1px 12px rgba(0,0,0,.35)}
.hero-dots{position:absolute;right:26px;top:46%;z-index:3;display:flex;flex-direction:column;gap:10px}
.hero-dots button{width:10px;height:10px;border-radius:50%;border:1.5px solid #cfccc4;background:transparent;cursor:pointer;padding:0}
.hero-dots button[aria-current="true"]{background:var(--brand);border-color:var(--brand)}
@media(max-width:820px){.hero-dots{display:none}}
/* scroll reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
/* hero entrance */
@keyframes riseIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.home-hero .eyebrow{animation:riseIn .7s ease .1s both}
.home-hero h1{animation:riseIn .8s ease .25s both}
.home-hero p{animation:riseIn .8s ease .4s both}
.home-hero .hero-actions{animation:riseIn .8s ease .55s both}
/* moving lane markings */
@keyframes laneMove{from{background-position:0 0}to{background-position:74px 0}}
.home-hero + .centerline, .home-hero .centerline{animation:laneMove 2.4s linear infinite}
.centerline{height:5px;width:100%;background:repeating-linear-gradient(90deg,var(--brand) 0 44px,transparent 44px 74px)}
/* brand associations */
.brands{margin-top:44px;display:grid;gap:18px}
.brand-row{display:grid;grid-template-columns:200px 1fr;gap:20px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:3px;padding:24px 26px}
.brand-row .cat{font-family:'Barlow Condensed';font-size:1.25rem;text-transform:uppercase;color:var(--ink);font-weight:700;line-height:1.1}
.brand-row .cat::after{content:"";display:block;width:28px;height:4px;background:var(--brand);margin-top:10px}
.brand-row .names{display:flex;flex-wrap:wrap;gap:10px}
.bname{background:var(--off);border:1px solid var(--line);border-radius:2px;padding:9px 16px;font-size:.88rem;font-weight:600;color:var(--body);white-space:nowrap}
.btile{background:var(--off);border:1px solid var(--line);border-radius:2px;padding:10px 18px;display:flex;align-items:center;min-height:52px}
.btile img{height:22px;width:auto;display:block}
@media(max-width:720px){.brand-row{grid-template-columns:1fr}}
@media (prefers-reduced-motion: reduce){.hero-slides .slide{transition:none;animation:none!important}.reveal{opacity:1;transform:none;transition:none}.home-hero .eyebrow,.home-hero h1,.home-hero p,.home-hero .hero-actions{animation:none}.centerline,.home-hero .centerline{animation:none!important}}
.home-hero::after{content:"";position:absolute;right:-160px;top:-160px;width:560px;height:560px;background:var(--brand);opacity:.08;transform:rotate(45deg);z-index:1}
.home-hero .wrap{position:relative;z-index:2}
.home-hero .eyebrow{color:var(--brand)}
.home-hero h1{color:#fff;font-size:clamp(3rem,8vw,5.4rem);font-weight:700;margin:10px 0 22px;max-width:880px}
.home-hero h1 em{font-style:normal;color:var(--brand)}
.home-hero p{max-width:620px;color:#b8b4aa;font-size:1.12rem;margin-bottom:38px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:68px}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid #34322b}
.hero-stats div{padding:26px 20px 30px;border-right:1px solid #34322b}
.hero-stats div:last-child{border-right:0}
.hero-stats b{font-family:'Barlow Condensed';font-size:2.5rem;font-weight:700;display:block;color:var(--brand)}
.hero-stats span{font-size:.76rem;color:#8b877d;letter-spacing:.1em;text-transform:uppercase}
@media(max-width:820px){.hero-stats{grid-template-columns:repeat(2,1fr)}.hero-stats div:nth-child(2n){border-right:0}}

/* ---------- generic grids & cards ---------- */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:3px;padding:32px 28px}
.alt .card{background:#fff}
.card.accent{border-top:4px solid var(--brand)}
.card h3 a{text-decoration:none}
.card h3 a:hover{color:var(--brand-deep)}
.card p{font-size:.94rem;color:var(--muted)}
.card .more{display:inline-block;margin-top:16px;font-size:.84rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--brand)}
.card .more:hover{color:var(--brand-deep)}
.num{font-family:'IBM Plex Mono';font-size:.7rem;color:var(--muted);letter-spacing:.12em}

/* two-column article layout */
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:start}
@media(max-width:880px){.split{grid-template-columns:1fr}}
.facts{background:var(--off);border:1px solid var(--line);border-radius:3px;padding:30px;border-top:4px solid var(--brand)}
.facts h3{font-size:1.1rem;margin-bottom:16px}
.facts dl{display:grid;grid-template-columns:auto 1fr;gap:11px 18px;font-size:.9rem}
.facts dt{color:var(--muted);white-space:nowrap}
.facts dd{font-weight:600;color:var(--ink)}

/* checklist */
ul.check{list-style:none}
ul.check li{padding:7px 0 7px 26px;position:relative;font-size:.95rem;color:var(--body)}
ul.check li::before{content:"";position:absolute;left:0;top:16px;width:12px;height:3px;background:var(--brand)}

/* timeline */
.timeline{margin-top:48px;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:3px;background:repeating-linear-gradient(180deg,var(--brand) 0 20px,transparent 20px 34px)}
.t-item{position:relative;padding-bottom:40px;max-width:700px}
.t-item:last-child{padding-bottom:0}
.t-item::before{content:"";position:absolute;left:-33px;top:8px;width:13px;height:13px;background:var(--ink);border-radius:50%;border:3px solid var(--brand)}
.t-item .year{font-family:'Barlow Condensed';font-size:1.4rem;font-weight:700;color:var(--brand-deep)}
.t-item h3{margin:2px 0 6px}
.t-item p{color:var(--muted);font-size:.96rem}

/* tables */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:3px}
table.data{width:100%;border-collapse:collapse;font-size:.87rem;min-width:660px}
table.data th{background:var(--ink);color:var(--brand);text-align:left;padding:13px 16px;font-family:'Barlow Condensed';text-transform:uppercase;font-size:.98rem;letter-spacing:.05em;font-weight:600}
table.data td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--body)}
table.data tr:nth-child(even) td{background:var(--off)}
table.data tr:last-child td{border-bottom:0}
table.data td.amt{white-space:nowrap;font-family:'IBM Plex Mono';font-size:.78rem;color:var(--ink)}
.table-note{font-size:.82rem;color:var(--muted);margin-top:12px}

/* tabs */
.tabs{display:flex;gap:8px;margin:34px 0 20px;flex-wrap:wrap}
.tab{background:none;border:1.5px solid var(--line);color:var(--ink);font:inherit;font-weight:600;font-size:.88rem;padding:10px 24px;border-radius:2px;cursor:pointer}
.tab[aria-selected="true"]{background:var(--brand);border-color:var(--brand)}
.panel{display:none}
.panel.active{display:block}

/* stat band */
.band{background:var(--brand);padding:44px 0}
.band .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.band b{font-family:'Barlow Condensed';font-size:2.3rem;font-weight:700;color:var(--ink);display:block;line-height:1}
.band span{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:#5c4a06;font-weight:600}
@media(max-width:820px){.band .wrap{grid-template-columns:repeat(2,1fr)}}

/* CTA band */
.cta-band{background:var(--ink);color:#fff;padding:72px 0}
.cta-band h2{color:#fff}
.cta-band p{color:#b8b4aa;max-width:640px}
.cta-band .actions{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}

/* client badges */
.badges{display:flex;flex-wrap:wrap;gap:10px}
.badge{background:#fff;border:1px solid var(--line);border-radius:2px;padding:11px 18px;font-size:.86rem;font-weight:600;color:var(--muted)}

/* leader cards */
.leader{background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.leader .bar{height:6px;background:var(--brand)}
.leader .body{padding:30px 28px}
.leader b{font-family:'Barlow Condensed';font-size:1.5rem;text-transform:uppercase;display:block;color:var(--ink)}
.leader span.role{color:var(--brand-deep);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700}
.leader p{color:var(--muted);font-size:.93rem;margin-top:12px}

/* leader with photo */
.leader .portrait{aspect-ratio:5/6;overflow:hidden;background:var(--off)}
.leader .portrait img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .5s ease}
.leader:hover .portrait img{transform:scale(1.04)}

/* founder feature */
.founder{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border:1px solid var(--line);border-radius:3px;overflow:hidden;margin-top:44px}
.founder .portrait{background:var(--off);min-height:440px;border-right:4px solid var(--brand)}
.founder .portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}
.founder .body{padding:44px 42px;display:flex;flex-direction:column;justify-content:center}
.founder .body .role{color:var(--brand-deep);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:6px}
.founder .body h2{margin-bottom:8px}
.founder .body .quote{border-left:4px solid var(--brand);padding:6px 0 6px 20px;margin:20px 0;font-family:'Barlow Condensed';font-size:1.5rem;line-height:1.2;color:var(--ink);text-transform:none}
.founder .body p{font-size:.95rem;color:var(--body)}
@media(max-width:820px){.founder{grid-template-columns:1fr}.founder .portrait{min-height:360px;border-right:none;border-bottom:4px solid var(--brand)}}

/* stat pills */
.pills{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}
.pill{background:var(--brand-soft);border:1px solid var(--brand);border-radius:2px;padding:10px 16px;font-size:.84rem;font-weight:600;color:var(--ink)}
.pill b{font-family:'Barlow Condensed';font-size:1.15rem;color:var(--brand-deep);margin-right:6px}

/* org values row */
.org-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}
@media(max-width:900px){.org-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.org-grid{grid-template-columns:1fr}}
.org{background:#fff;border:1px solid var(--line);border-radius:3px;padding:26px 22px;border-top:4px solid var(--brand)}
.org b{font-family:'Barlow Condensed';font-size:1.15rem;text-transform:uppercase;display:block;margin-bottom:8px;color:var(--ink)}
.org p{font-size:.88rem;color:var(--muted)}

/* iso badges */
.iso-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.iso{background:var(--ink);color:#fff;border-radius:3px;padding:28px;text-align:center}
.iso b{font-family:'Barlow Condensed';font-size:1.6rem;color:var(--brand);display:block}
.iso span{font-size:.8rem;color:#b8b4aa;letter-spacing:.06em;text-transform:uppercase}
.iso .mono{display:block;margin-top:10px;color:#8b877d}
@media(max-width:760px){.iso-row{grid-template-columns:1fr}}

/* job list */
.job{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:2px;padding:22px 24px;margin-bottom:14px}
.job b{font-family:'Barlow Condensed';font-size:1.3rem;text-transform:uppercase;display:block;color:var(--ink)}
.job p{font-size:.92rem;color:var(--muted);margin-top:6px}

/* contact cards */
.c-card{background:#fff;border:1px solid var(--line);border-radius:3px;padding:30px 28px}
.c-card h3{color:var(--ink)}
.c-card h3::before{content:"";display:block;width:30px;height:4px;background:var(--brand);margin-bottom:12px}
.c-card address,.c-card p{font-style:normal;font-size:.93rem;color:var(--muted);line-height:1.85}
.c-card a{color:var(--brand-deep);text-decoration:none;font-weight:600}
.c-card a:hover{text-decoration:underline}
.hours{width:100%;font-size:.9rem;color:var(--muted);border-collapse:collapse}
.hours td{padding:7px 0;border-bottom:1px dashed var(--line)}
.hours td:last-child{text-align:right;color:var(--ink);font-weight:600}

/* media cards (image + text) */
.mcard{background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.mcard .ph{aspect-ratio:16/10;overflow:hidden;background:var(--off)}
.mcard .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.mcard:hover .ph img{transform:scale(1.04)}
.mcard .body{padding:24px 24px 28px}
.mcard h3{margin-bottom:8px}
.mcard p{font-size:.92rem;color:var(--muted)}
.mcard .num{display:block;margin-bottom:6px}

/* project feature with image */
.pfeature{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:3px;overflow:hidden;margin-top:44px}
.pfeature + .pfeature{margin-top:24px}
.pfeature .ph{min-height:300px;background:var(--off)}
.pfeature .ph img{width:100%;height:100%;object-fit:cover;display:block}
.pfeature .body{padding:38px 36px;display:flex;flex-direction:column;justify-content:center}
.pfeature.rev .ph{order:2}
.pfeature .body .num{margin-bottom:8px}
.pfeature .body .val{background:none;padding:0;margin-top:16px;font-family:'Barlow Condensed';font-size:1.2rem;color:var(--brand-deep);font-weight:700}
@media(max-width:820px){.pfeature{grid-template-columns:1fr}.pfeature.rev .ph{order:0}.pfeature .ph{min-height:220px}}

/* image band in hero of interior page */
.hero-media{display:grid;grid-template-columns:1.2fr .8fr;gap:44px;align-items:center;margin-top:8px}
.hero-media .ph{border-radius:3px;overflow:hidden;aspect-ratio:16/10}
.hero-media .ph img{width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.hero-media{grid-template-columns:1fr}}

/* fleet gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:44px}
.gitem{border:1px solid var(--line);border-radius:3px;overflow:hidden;background:#fff}
.gitem .ph{aspect-ratio:4/3;overflow:hidden}
.gitem .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.gitem:hover .ph img{transform:scale(1.05)}
.gitem .cap{padding:11px 14px}
.gitem b{font-family:'Barlow Condensed';font-size:1.02rem;text-transform:uppercase;display:block;color:var(--ink);line-height:1.15}
.gitem span{font-size:.76rem;color:var(--muted)}
@media(max-width:960px){.gallery{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* news / press */
.news-band{background:var(--brand-soft);border-top:3px solid var(--brand);border-bottom:3px solid var(--brand)}
.news-card{display:grid;grid-template-columns:auto 1fr auto;gap:26px;align-items:center}
.news-card .tagcol{font-family:'IBM Plex Mono';font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brand-deep);writing-mode:horizontal-tb;font-weight:600}
.news-card h3{font-size:1.5rem;margin-bottom:6px;max-width:640px}
.news-card p{font-size:.94rem;color:var(--body);max-width:680px}
.news-card .src{font-size:.8rem;color:var(--muted);margin-top:8px}
@media(max-width:820px){.news-card{grid-template-columns:1fr;gap:16px}}
.press-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:44px}
@media(max-width:760px){.press-grid{grid-template-columns:1fr}}
.press{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:2px;padding:26px 28px}
.press .meta{font-family:'IBM Plex Mono';font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.press h3{font-size:1.25rem;margin-bottom:10px}
.press p{font-size:.92rem;color:var(--muted)}
.press a.more{display:inline-block;margin-top:14px;font-size:.82rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--brand)}
.press a.more:hover{color:var(--brand-deep)}

/* client logos */
.clients-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:44px}
.clogo{background:#fff;border:1px solid var(--line);border-radius:3px;padding:18px 16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;min-height:158px}
.clogo img{max-height:76px;max-width:100%;object-fit:contain;mix-blend-mode:multiply}
.clogo span{font-size:.72rem;color:var(--muted);font-weight:600;line-height:1.3}
@media(max-width:900px){.clients-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.clients-grid{grid-template-columns:repeat(2,1fr)}}

/* live project gallery */
.pgallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:44px;grid-auto-rows:210px}
.pgallery a{position:relative;overflow:hidden;border-radius:3px;display:block;background:var(--off)}
.pgallery a.wide{grid-column:span 2}
.pgallery a.tall{grid-row:span 2}
.pgallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.pgallery a:hover img{transform:scale(1.06)}
.pgallery .cap{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(20,18,16,.82));color:#fff;font-size:.8rem;padding:26px 14px 12px;font-weight:500}
@media(max-width:820px){.pgallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}.pgallery a.tall{grid-row:auto}}
@media(max-width:520px){.pgallery{grid-template-columns:1fr;grid-auto-rows:230px}.pgallery a.wide{grid-column:auto}}

/* forms */
.formcard{background:#fff;border:1px solid var(--line);border-radius:3px;padding:36px 34px;border-top:4px solid var(--brand)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:620px){.frow{grid-template-columns:1fr}}
.field{margin-bottom:18px}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin-bottom:7px}
.field label .req{color:var(--brand-deep)}
.field input,.field select,.field textarea{width:100%;font:inherit;font-size:.95rem;padding:12px 14px;border:1px solid var(--line);border-radius:3px;background:var(--off);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand-deep);background:#fff}
.field textarea{resize:vertical;min-height:110px}
.field .hint{font-size:.78rem;color:var(--muted);margin-top:6px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:12px}
.checkline{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--body);margin-bottom:18px}
.checkline input{width:auto;margin-top:5px;flex-shrink:0}

/* steps */
.steps{counter-reset:step;list-style:none;margin-top:8px}
.steps li{position:relative;padding:0 0 26px 56px;counter-increment:step}
.steps li::before{content:counter(step);position:absolute;left:0;top:0;width:38px;height:38px;background:var(--brand);color:var(--ink);border-radius:50%;display:grid;place-items:center;font-family:'Barlow Condensed';font-weight:700;font-size:1.2rem}
.steps li::after{content:"";position:absolute;left:18px;top:38px;bottom:0;width:2px;background:var(--line)}
.steps li:last-child{padding-bottom:0}
.steps li:last-child::after{display:none}
.steps li b{font-family:'Barlow Condensed';font-size:1.2rem;text-transform:uppercase;display:block;color:var(--ink);margin-bottom:4px}
.steps li p{font-size:.92rem;color:var(--muted)}

/* brand associations */
.brand-rows{margin-top:44px;border-top:1px solid var(--line)}
.brand-row{display:grid;grid-template-columns:190px 1fr;gap:20px;padding:22px 0;border-bottom:1px solid var(--line);align-items:start}
.brand-row .cat{font-family:'Barlow Condensed';font-size:1.2rem;text-transform:uppercase;font-weight:700;color:var(--ink);padding-top:6px}
.brand-row .cat::after{content:"";display:block;width:26px;height:3px;background:var(--brand);margin-top:8px}
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{background:#fff;border:1px solid var(--line);border-radius:2px;padding:9px 18px;font-size:.88rem;font-weight:600;color:var(--body)}
.chip:hover{border-color:var(--brand)}
@media(max-width:680px){.brand-row{grid-template-columns:1fr;gap:10px}}

/* CSR strip */
.csr-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:40px}
.csr-strip .ph{aspect-ratio:4/3;overflow:hidden;border-radius:3px;position:relative}
.csr-strip img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.csr-strip .ph:hover img{transform:scale(1.05)}
@media(max-width:820px){.csr-strip{grid-template-columns:repeat(2,1fr)}}

/* scroll reveal animation */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .65s ease,transform .65s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}

/* icon badges */
.icb{width:54px;height:54px;background:var(--brand);border-radius:3px;display:grid;place-items:center;margin-bottom:16px;flex-shrink:0}
.icb svg{width:26px;height:26px;stroke:var(--ink);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.icb.dark{background:var(--ink)}
.icb.dark svg{stroke:var(--brand)}
.ic-inline{display:flex;gap:18px;align-items:flex-start}
.ic-inline .icb{margin-bottom:0}

/* footer */
footer{background:var(--ink);color:#8b877d;padding:64px 0 0;font-size:.88rem}
.f-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:48px}
@media(max-width:920px){.f-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.f-grid{grid-template-columns:1fr}}
footer h4{color:#fff;font-size:1.05rem;margin-bottom:16px;letter-spacing:.06em}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:#8b877d;text-decoration:none}
footer a:hover{color:var(--brand)}
.f-brand p{margin-top:14px;max-width:300px}
.f-tag{color:var(--brand);font-family:'IBM Plex Mono';font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-top:14px}
.f-bottom{border-top:1px solid #2b2923;padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem}

/* client logo marquee */
.marquee{overflow:hidden;position:relative;margin-top:44px;--gap:16px}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--off),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--off),transparent)}
.marquee-track{display:flex;gap:var(--gap);width:max-content;animation:marquee 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(calc(-50% - var(--gap)/2))}}
.marquee .clogo{min-width:190px;flex-shrink:0}
@media (prefers-reduced-motion: reduce){.marquee-track{animation:none;flex-wrap:wrap;width:auto}.marquee::before,.marquee::after{display:none}}
