/*
Theme Name:  Roca Group
Theme URI:   https://rocagroup.co.uk
Author:      Roca Group
Description: Premium construction portfolio theme. Custom post types for Projects & Sectors, ACF-powered content, fully responsive, WP Rocket compatible.
Version:     1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License:     Proprietary
Text Domain: roca-group
*/

/* ── TOKENS ─────────────────────────────────────────────── */
:root{
  --amber:#D3985E; --amber-d:#B8783E; --amber-l:#E8B882;
  --black:#0D0D0D; --dark:#111111; --dark2:#1A1A1A; --dark3:#242424;
  --white:#FFFFFF; --off:#F8F6F3; --off2:#F0EDE8;
  --gray:#6B6B6B; --lgray:#E5E2DC;
  --radius:4px;
}

/* ── RESET ──────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Inter',sans-serif;background:var(--white);color:var(--black);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
h1,h2,h3,h4,h5{font-family:'Syne',sans-serif;font-weight:800;letter-spacing:-0.5px;line-height:1.05}

/* ── LAYOUT ─────────────────────────────────────────────── */
.container{max-width:1280px;margin:0 auto;padding:0 48px}
.section-pad{padding:80px 0}
.section-pad-sm{padding:64px 0}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn-amber{display:inline-flex;align-items:center;gap:8px;background:var(--amber);color:var(--black);font-family:'Syne',sans-serif;font-size:13px;font-weight:700;padding:14px 28px;border-radius:var(--radius);transition:background .2s,transform .15s;cursor:pointer;border:none}
.btn-amber:hover{background:var(--amber-d);transform:translateY(-2px);color:var(--black)}
.btn-white{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--white);font-family:'Syne',sans-serif;font-size:13px;font-weight:600;padding:14px 28px;border-radius:var(--radius);transition:background .2s,border-color .2s}
.btn-white:hover{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.45);color:var(--white)}
.btn-submit{width:100%;background:var(--amber);color:var(--black);font-family:'Syne',sans-serif;font-weight:800;font-size:14px;padding:16px;border-radius:var(--radius);transition:background .2s,transform .15s;border:none;cursor:pointer}
.btn-submit:hover{background:var(--amber-d);transform:translateY(-1px)}

/* ── LABELS / HEADINGS ──────────────────────────────────── */
.section-label{display:flex;align-items:center;gap:10px;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--amber);margin-bottom:12px}
.section-label::before{content:'';width:24px;height:2px;background:var(--amber);flex-shrink:0}
.section-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(28px,3.5vw,48px);line-height:1.05;letter-spacing:-1px;color:var(--white)}
.section-h.dark{color:var(--black)}
.section-h span{color:var(--amber)}
.link-arrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--amber);padding:10px 0;border-bottom:1px solid transparent;transition:border-color .2s}
.link-arrow:hover{border-bottom-color:var(--amber);color:var(--amber)}
.link-arrow svg{transition:transform .2s}
.link-arrow:hover svg{transform:translateX(3px)}

/* ── NAV ────────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:500;height:68px;transition:background .3s,box-shadow .3s}
#nav.scrolled{background:rgba(255,255,255,.97);box-shadow:0 1px 0 rgba(0,0,0,.08);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}
#nav.dark-nav{background:transparent}
#nav.dark-nav.scrolled{background:rgba(13,13,13,.97)}
.nav-inner{height:68px;display:flex;align-items:center;justify-content:space-between}
.nav-logo{display:flex;align-items:baseline;gap:3px}
.nav-logo .w1{font-family:'Syne',sans-serif;font-weight:800;font-size:26px;letter-spacing:-1px;color:var(--white);transition:color .3s}
.nav-logo .w2{font-family:'Inter',sans-serif;font-weight:300;font-size:13px;color:var(--amber);margin-left:2px}
#nav.scrolled .nav-logo .w1{color:var(--black)}
#nav.dark-nav .nav-logo .w1,#nav.dark-nav.scrolled .nav-logo .w1{color:var(--white)}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-link{font-size:13px;font-weight:500;padding:8px 14px;color:rgba(255,255,255,.8);border-radius:var(--radius);transition:color .2s,background .2s}
.nav-link:hover,.nav-link.current-menu-item{color:var(--white);background:rgba(255,255,255,.1)}
#nav.scrolled .nav-link{color:var(--gray)}
#nav.scrolled .nav-link:hover,#nav.scrolled .nav-link.current-menu-item{color:var(--black);background:var(--off)}
#nav.dark-nav .nav-link,#nav.dark-nav.scrolled .nav-link{color:rgba(255,255,255,.75)}
#nav.dark-nav.scrolled .nav-link:hover{color:var(--white)}
.nav-btn{background:var(--amber);color:var(--black);font-family:'Syne',sans-serif;font-size:12px;font-weight:700;padding:10px 22px;border-radius:var(--radius);transition:background .2s,transform .1s}
.nav-btn:hover{background:var(--amber-d);transform:translateY(-1px);color:var(--black)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:6px}
.nav-toggle span{width:22px;height:2px;background:var(--white);border-radius:2px;transition:transform .3s,opacity .3s}
#nav.scrolled .nav-toggle span{background:var(--black)}
.nav-drawer{display:none;flex-direction:column;position:fixed;top:68px;left:0;right:0;bottom:0;background:var(--white);padding:32px 24px;z-index:400;overflow-y:auto}
.nav-drawer.open{display:flex}
.nav-drawer a{font-family:'Syne',sans-serif;font-weight:700;font-size:28px;padding:18px 0;border-bottom:1px solid var(--lgray);color:var(--black)}
.nav-drawer a:hover{color:var(--amber)}
.nav-drawer .drawer-cta{margin-top:28px;background:var(--amber);color:var(--black);text-align:center;padding:16px;font-weight:700;font-size:14px;letter-spacing:1px;text-transform:uppercase;border:none;border-bottom:none!important}
.admin-bar #nav{top:32px}

/* ── PAGE HERO (inner pages) ────────────────────────────── */
.page-hero{position:relative;height:420px;display:flex;align-items:flex-end;overflow:hidden;padding-top:68px}
.page-hero-img{position:absolute;inset:0}
.page-hero-img img{width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.75) 0%,rgba(0,0,0,.3) 100%)}
.page-hero-content{position:relative;z-index:2;padding-bottom:60px}
.page-hero-eyebrow{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--amber);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.page-hero-eyebrow::before{content:'';width:24px;height:2px;background:var(--amber)}
.page-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(36px,5vw,72px);color:var(--white);letter-spacing:-2px;line-height:.95}
.page-h span{color:var(--amber)}

/* ── HOME HERO ──────────────────────────────────────────── */
/* Hero: flex-column so content grows above stats bar — stats bar stays in document flow */
.hero{position:relative;height:100vh;height:100dvh;min-height:640px;display:flex;flex-direction:column;overflow:hidden}
.hero .hero-img{position:absolute;inset:0}
.hero .hero-img img{width:100%;height:100%;object-fit:cover}
.hero-gradient{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.75) 0%,rgba(0,0,0,.4) 55%,rgba(0,0,0,.1) 100%),linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 50%)}
.hero-content{position:relative;z-index:2;padding:68px 0 48px;width:100%;flex:1;display:flex;align-items:flex-end}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--amber);margin-bottom:20px}
.hero-eyebrow::before{content:'';width:28px;height:1px;background:var(--amber)}
.hero h1{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(44px,7vw,96px);line-height:.95;letter-spacing:-2px;color:var(--white);max-width:760px}
.hero h1 em{color:var(--amber);font-style:normal;display:block}
.hero-sub{font-size:16px;color:rgba(255,255,255,.72);line-height:1.7;max-width:460px;margin:24px 0 40px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-stats-bar{position:relative;z-index:3;background:rgba(255,255,255,.06);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}
.hero-stats-inner{display:flex;align-items:stretch}
.hstat{flex:1;padding:24px 32px;display:flex;flex-direction:column;gap:4px;border-right:1px solid rgba(255,255,255,.1)}
.hstat:last-child{border-right:none}
.hstat-num{font-family:'Syne',sans-serif;font-weight:800;font-size:36px;color:var(--amber);letter-spacing:-1px;line-height:1}
.hstat-label{font-size:11px;font-weight:500;color:rgba(255,255,255,.55);letter-spacing:1px;text-transform:uppercase}

/* ── ABOUT STRIP ────────────────────────────────────────── */
.about-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center}
.about-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(28px,3.5vw,48px);line-height:1.1;letter-spacing:-1px;color:var(--black)}
.about-h span{color:var(--amber)}
.about-right p{font-size:15px;color:var(--gray);line-height:1.85;margin-bottom:20px}
.about-pillars{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
.pillar{display:flex;align-items:flex-start;gap:12px;padding:18px;background:var(--off);border-radius:var(--radius);border-left:3px solid transparent;transition:border-color .2s}
.pillar:hover{border-left-color:var(--amber)}
.pillar-icon{width:36px;height:36px;flex-shrink:0;background:var(--amber);border-radius:var(--radius);display:flex;align-items:center;justify-content:center}
.pillar-icon svg{width:16px;height:16px;stroke:var(--black);fill:none;stroke-width:2}
.pillar-title{font-size:13px;font-weight:700;color:var(--black);margin-bottom:3px}
.pillar-text{font-size:12px;color:var(--gray);line-height:1.5}

/* ── SECTORS GRID ───────────────────────────────────────── */
.sectors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.sector-card{position:relative;height:320px;overflow:hidden;cursor:pointer}
.sector-card-img{position:absolute;inset:0;transition:transform .5s ease}
.sector-card-img img{width:100%;height:100%;object-fit:cover}
.sector-card:hover .sector-card-img{transform:scale(1.06)}
.sector-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.2) 60%,transparent 100%);transition:background .3s}
.sector-card:hover .sector-card-overlay{background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.35) 60%,rgba(211,152,94,.08) 100%)}
.sector-card-body{position:absolute;bottom:0;left:0;right:0;padding:24px;transform:translateY(4px);transition:transform .3s}
.sector-card:hover .sector-card-body{transform:translateY(0)}
.sc-icon{width:36px;height:2px;background:var(--amber);margin-bottom:12px}
.sc-title{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;color:var(--white)}
.sc-count{font-size:11px;color:var(--amber);letter-spacing:1px;margin-top:6px;font-weight:600;opacity:0;transition:opacity .3s}
.sector-card:hover .sc-count{opacity:1}

/* ── FEATURED PROJECTS ──────────────────────────────────── */
.projects-featured{display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:340px 240px;gap:3px}
.pf-card{position:relative;overflow:hidden;cursor:pointer;background:var(--dark2)}
.pf-card-img{position:absolute;inset:0;transition:transform .5s ease}
.pf-card-img img{width:100%;height:100%;object-fit:cover}
.pf-card:hover .pf-card-img{transform:scale(1.04)}
.pf-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 60%)}
.pf-card-body{position:absolute;bottom:0;left:0;right:0;padding:24px 28px}
.pf-card.main{grid-row:span 2}
.pf-card.main .pf-card-body{padding:32px}
.pf-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;margin-bottom:10px;border-radius:2px}
.pf-tag.current{background:#1B4332;color:#B7E4C7}
.pf-tag.done{background:var(--amber);color:var(--black)}
.pf-title{font-family:'Syne',sans-serif;font-weight:800;font-size:22px;color:var(--white);line-height:1.1}
.pf-card.main .pf-title{font-size:30px}
.pf-meta{font-size:12px;color:rgba(255,255,255,.5);margin-top:8px}
.pf-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:12px;font-weight:700;color:var(--amber)}
.pf-link svg{transition:transform .2s}
.pf-card:hover .pf-link svg{transform:translateX(4px)}

/* ── WHY ROCA ───────────────────────────────────────────── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.why-image{position:relative;height:520px;overflow:hidden;border-radius:var(--radius)}
.why-image img{width:100%;height:100%;object-fit:cover}
.why-image-badge{position:absolute;bottom:28px;left:28px;right:28px;background:rgba(0,0,0,.85);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);padding:20px 24px;border-radius:var(--radius);display:flex;align-items:center;gap:16px}
.wib-icon{width:44px;height:44px;background:var(--amber);border-radius:var(--radius);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.wib-icon svg{width:20px;height:20px;stroke:var(--black);fill:none;stroke-width:2}
.wib-text strong{display:block;font-family:'Syne',sans-serif;font-weight:700;font-size:16px;color:var(--white)}
.wib-text span{font-size:12px;color:rgba(255,255,255,.5)}
.why-items{display:flex;flex-direction:column}
.why-item{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--lgray)}
.why-item:last-child{border-bottom:none}
.wi-num{font-family:'Syne',sans-serif;font-weight:800;font-size:13px;color:var(--amber);min-width:28px}
.wi-title{font-size:14px;font-weight:700;color:var(--black);margin-bottom:4px}
.wi-text{font-size:13px;color:var(--gray);line-height:1.6}

/* ── TESTIMONIAL ────────────────────────────────────────── */
.testi-inner{max-width:800px;margin:0 auto;text-align:center}
.testi-quote-mark{font-family:'Syne',sans-serif;font-size:80px;font-weight:800;color:rgba(0,0,0,.12);line-height:.6;margin-bottom:24px}
.testi-text{font-family:'Syne',sans-serif;font-weight:600;font-size:clamp(18px,2.5vw,28px);color:var(--black);line-height:1.45;margin-bottom:28px}
.testi-author{display:flex;align-items:center;justify-content:center;gap:14px}
.testi-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden}
.testi-avatar img{width:100%;height:100%;object-fit:cover}
.testi-name strong{display:block;font-size:14px;font-weight:700;color:var(--black)}
.testi-name span{font-size:12px;color:rgba(0,0,0,.55)}

/* ── CTA SECTION ────────────────────────────────────────── */
.cta-section{position:relative;padding:100px 0;overflow:hidden;background:var(--dark)}
.cta-bg{position:absolute;inset:0;opacity:.2}
.cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-overlay{position:absolute;inset:0;background:rgba(10,10,10,.75)}
.cta-content{position:relative;z-index:2;text-align:center;max-width:640px;margin:0 auto}
.cta-content .section-label{justify-content:center}
.cta-content .section-label::before{display:none}
.cta-h{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(28px,4vw,56px);color:var(--white);letter-spacing:-1px;line-height:1.05;margin:12px 0 20px}
.cta-h span{color:var(--amber)}
.cta-p{font-size:15px;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:40px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── APPROACH — PROCESS ─────────────────────────────────── */
.process-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:56px}
.process-card{background:var(--off);padding:40px 36px;border-left:3px solid transparent;transition:border-color .3s,background .3s}
.process-card:hover{border-left-color:var(--amber);background:var(--off2)}
.process-card.highlight{background:var(--amber);border-left-color:transparent}
.process-card.highlight:hover{background:var(--amber-d)}
.pc-num{font-family:'Syne',sans-serif;font-weight:800;font-size:48px;color:rgba(211,152,94,.15);line-height:1;margin-bottom:16px}
.process-card.highlight .pc-num{color:rgba(0,0,0,.15)}
.pc-title{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;color:var(--black);margin-bottom:10px}
.process-card.highlight .pc-title{color:var(--black)}
.pc-text{font-size:13px;color:var(--gray);line-height:1.75}
.process-card.highlight .pc-text{color:rgba(0,0,0,.6)}
.pc-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);background:rgba(211,152,94,.1);padding:4px 10px;margin-top:16px}

/* ── VALUES ─────────────────────────────────────────────── */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:56px}
.value-card{background:var(--dark2);padding:36px 32px;border-bottom:2px solid transparent;transition:border-color .3s,background .3s}
.value-card:hover{background:var(--dark3);border-bottom-color:var(--amber)}
.vc-icon{width:44px;height:44px;background:rgba(211,152,94,.12);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.vc-icon svg{width:20px;height:20px;stroke:var(--amber);fill:none;stroke-width:1.5}
.vc-title{font-family:'Syne',sans-serif;font-weight:700;font-size:16px;color:var(--white);margin-bottom:10px}
.vc-text{font-size:13px;color:rgba(255,255,255,.45);line-height:1.7}

/* ── TEAM ───────────────────────────────────────────────── */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-top:56px}
.team-card{overflow:hidden;background:var(--white);transition:transform .3s}
.team-card:hover{transform:translateY(-4px)}
.team-photo{height:260px;overflow:hidden;background:var(--off2)}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.team-card:hover .team-photo img{transform:scale(1.05)}
.team-info{padding:20px}
.team-name{font-family:'Syne',sans-serif;font-weight:700;font-size:16px;color:var(--black)}
.team-role{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);margin-top:4px}

/* ── SECTORS FULL (page) ────────────────────────────────── */
.sector-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;padding:64px 0;border-bottom:1px solid var(--lgray)}
.sector-row:last-child{border-bottom:none}
.sector-row.rev{direction:rtl}
.sector-row.rev>*{direction:ltr}
.sector-img{height:360px;overflow:hidden;border-radius:var(--radius)}
.sector-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.sector-img:hover img{transform:scale(1.03)}
.sector-num{font-family:'Syne',sans-serif;font-weight:800;font-size:56px;color:rgba(211,152,94,.1);line-height:1}
.sector-title{font-family:'Syne',sans-serif;font-weight:800;font-size:28px;color:var(--black);letter-spacing:-.5px;margin-top:4px;margin-bottom:14px}
.sector-title span{color:var(--amber)}
.sector-body-text{font-size:14px;color:var(--gray);line-height:1.85;margin-bottom:24px}
.sector-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.chip{background:var(--off2);color:var(--gray);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:6px 14px;border-radius:2px;transition:background .2s,color .2s}
.chip:hover{background:var(--amber);color:var(--black)}

/* ── PROJECTS ───────────────────────────────────────────── */
.projects-hero-section{background:var(--dark);padding:calc(68px + 80px) 0 80px}
.filter-bar{background:var(--white);border-bottom:1px solid var(--lgray);position:sticky;top:68px;z-index:100}
.filter-tabs{display:flex;gap:0;overflow-x:auto}
.filter-tab{padding:16px 28px;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray);border-bottom:2px solid transparent;white-space:nowrap;transition:all .2s;background:none;cursor:pointer}
.filter-tab:hover{color:var(--black)}
.filter-tab.active{color:var(--amber);border-bottom-color:var(--amber)}
.projects-masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}
.proj-card{overflow:hidden;cursor:pointer;background:var(--off2)}
.proj-card.h2 .proj-img{height:560px}
.proj-img{overflow:hidden}
.proj-card:not(.h2) .proj-img{height:280px}
.proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.proj-card:hover .proj-img img{transform:scale(1.05)}
.proj-body{padding:20px 22px 24px;background:var(--white)}
.proj-tags-row{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.tag{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:4px 10px;border-radius:2px}
.tag-amber{background:var(--amber);color:var(--black)}
.tag-current{background:#1B4332;color:#B7E4C7}
.tag-outline{border:1px solid var(--lgray);color:var(--gray)}
.proj-title{font-family:'Syne',sans-serif;font-weight:700;font-size:17px;color:var(--black);letter-spacing:-.2px;margin-bottom:6px}
.proj-sub{font-size:12px;color:var(--gray)}
.proj-link{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:12px;font-weight:700;color:var(--amber)}
.proj-link svg{transition:transform .2s}
.proj-card:hover .proj-link svg{transform:translateX(4px)}

/* Single project */
.single-project-hero{position:relative;height:60vh;min-height:420px;display:flex;align-items:flex-end;overflow:hidden;padding-top:68px}
.project-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:60px;align-items:start;padding:60px 0 80px}
.project-meta-card{background:var(--off);padding:32px;border-radius:var(--radius);position:sticky;top:88px}
.meta-row{display:flex;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--lgray);font-size:13px}
.meta-row:last-child{border-bottom:none}
.meta-key{color:var(--gray);font-weight:500}
.meta-val{color:var(--black);font-weight:700;text-align:right}
.project-gallery{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:32px}
.gallery-img{height:240px;overflow:hidden}
.gallery-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery-img:hover img{transform:scale(1.04)}

/* ── CONTACT ────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:start}
.contact-detail{display:flex;align-items:flex-start;gap:16px;padding:20px 0;border-bottom:1px solid var(--lgray)}
.contact-detail:last-of-type{border-bottom:none}
.cd-icon{width:40px;height:40px;background:rgba(211,152,94,.1);border-radius:var(--radius);flex-shrink:0;display:flex;align-items:center;justify-content:center}
.cd-icon svg{width:16px;height:16px;stroke:var(--amber);fill:none;stroke-width:1.5}
.cd-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--amber);margin-bottom:4px}
.cd-val{font-size:14px;color:var(--black);font-weight:500}
.cd-sub{font-size:12px;color:var(--gray);margin-top:2px}
.contact-form-wrap{background:var(--off);padding:40px;border-radius:var(--radius)}
.cf-title{font-family:'Syne',sans-serif;font-weight:800;font-size:20px;color:var(--black);margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--black)}
input[type=text],input[type=email],input[type=tel],input[type=url],textarea,select{background:var(--white);border:1.5px solid var(--lgray);color:var(--black);padding:12px 16px;font-family:'Inter',sans-serif;font-size:14px;border-radius:var(--radius);outline:none;width:100%;transition:border-color .2s}
input:focus,textarea:focus,select:focus{border-color:var(--amber)}
textarea{height:100px;resize:vertical}
select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B6B6B' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.wpcf7-not-valid-tip{color:#e53e3e;font-size:12px;margin-top:4px}
.wpcf7-response-output{margin-top:16px;padding:12px 16px;border-radius:var(--radius);font-size:13px}

/* Offices */
.offices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:40px}
.office-card{background:var(--dark2);padding:32px}
.office-badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:4px 10px;margin-bottom:16px;border-radius:2px}
.office-badge.primary{background:var(--amber);color:var(--black)}
.office-badge.secondary{background:var(--dark3);color:var(--amber);border:1px solid rgba(211,152,94,.2)}
.office-title{font-family:'Syne',sans-serif;font-weight:700;font-size:18px;color:var(--white);margin-bottom:14px}
.office-detail{font-size:13px;color:rgba(255,255,255,.45);line-height:2}

/* ── FOOTER ─────────────────────────────────────────────── */
.site-footer{background:var(--black);padding:64px 0 32px;border-top:1px solid rgba(255,255,255,.05)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.footer-desc{font-size:13px;color:rgba(255,255,255,.38);line-height:1.85;max-width:220px;margin:16px 0 24px}
.footer-social{display:flex;gap:8px}
.social-btn{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s;cursor:pointer;background:none}
.social-btn:hover{border-color:var(--amber);background:rgba(211,152,94,.08)}
.social-btn svg{width:14px;height:14px;stroke:rgba(255,255,255,.45);fill:none;stroke-width:1.5;transition:stroke .2s}
.social-btn:hover svg{stroke:var(--amber)}
.footer-col h4{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--amber);margin-bottom:20px}
.footer-col li{margin-bottom:12px}
.footer-col a{font-size:13px;color:rgba(255,255,255,.38);transition:color .2s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:11px;color:rgba(255,255,255,.22)}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{font-size:11px;color:rgba(255,255,255,.3);transition:color .2s}
.footer-bottom-links a:hover{color:var(--white)}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1024px){
  .about-inner{grid-template-columns:1fr;gap:40px}
  .sectors-grid{grid-template-columns:1fr 1fr}
  .projects-featured{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .pf-card.main{grid-row:auto;grid-column:span 2}
  .why-grid{grid-template-columns:1fr;gap:40px}
  .why-image{height:360px}
  .team-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .projects-masonry{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .sector-row,.sector-row.rev{grid-template-columns:1fr;direction:ltr}
  .project-detail-grid{grid-template-columns:1fr}
  .project-meta-card{position:static}
}
@media(max-width:768px){
  .container{padding:0 20px}
  .nav-links,.nav-btn{display:none}
  .nav-toggle{display:flex}
  .sectors-grid{grid-template-columns:1fr 1fr}
  .projects-featured{grid-template-columns:1fr}
  .pf-card.main{grid-column:auto}
  .process-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .about-pillars{grid-template-columns:1fr}
  .offices-grid{grid-template-columns:1fr}
  .hstat{padding:16px 20px;min-width:50%;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}
  .hero-content{padding:68px 0 32px}
  .hero-stats-inner{flex-wrap:wrap}
  .admin-bar #nav{top:46px}
}
@media(max-width:480px){
  .sectors-grid,.values-grid,.projects-masonry,.footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .proj-card.h2 .proj-img{height:280px}
}

/* ── iOS / SAFARI SPECIFIC ──────────────────────────────────── */
/* Prevent iOS auto-zoom on form inputs (font-size must be ≥16px) */
@media(max-width:768px){
  input[type=text],input[type=email],input[type=tel],
  input[type=url],textarea,select{font-size:16px}
}
/* Remove iOS tap highlight on interactive elements */
a,button,.filter-tab,.sector-card,.proj-card,.team-card{
  -webkit-tap-highlight-color:transparent;
}
/* Safe area insets for iPhone notch / home bar */
#nav{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}
.site-footer{padding-bottom:calc(32px + env(safe-area-inset-bottom))}
/* Smooth momentum scrolling on iOS */
.filter-tabs{-webkit-overflow-scrolling:touch}
/* Fix for dark-nav scrolled state on dark mode Safari */
#nav.dark-nav.scrolled{background:rgba(13,13,13,.97);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}

