/* ============================================================
   One Personnel — Site stylesheet
   Refined-Motion aesthetic (editorial monochrome) + a restrained
   safety-orange accent and structural edge bars borrowed from the
   Modern Civil direction.
   ============================================================ */

:root{
  --ink:#0f0f0f; --ink-2:#1a1a1a; --line-ink:#2a2a2a; --paper:#f6f5f1;
  --grey-6:#46453f; --grey-5:#555; --grey-4:#8a8a86; --grey-3:#cfcec9; --line:#dad9d3;
  --orange:#e0531f; --orange-soft:#ec6a3a;
  --serif:'Playfair Display',serif; --sans:'Barlow',sans-serif; --cond:'Barlow Condensed',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --gutter:48px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:300;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
::selection{background:var(--orange);color:#fff;}

/* ---- scroll progress + cursor ---- */
#progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--orange);z-index:300;transition:width .1s linear;}
#dot,#ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:400;mix-blend-mode:difference;}
#dot{width:6px;height:6px;background:#fff;margin:-3px 0 0 -3px;}
#ring{width:38px;height:38px;border:1px solid rgba(255,255,255,.7);margin:-19px 0 0 -19px;transition:width .25s var(--ease),height .25s var(--ease),margin .25s var(--ease),opacity .25s;}
#ring.big{width:64px;height:64px;margin:-32px 0 0 -32px;border-color:var(--orange);}
@media (hover:none),(pointer:coarse){#dot,#ring{display:none;}}

/* ---- nav ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;
  padding:24px var(--gutter);transition:padding .4s var(--ease),background .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;}
nav.solid{padding:15px var(--gutter);background:rgba(10,10,10,.96);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-ink);}
nav .brand{display:flex;align-items:center;gap:13px;color:#fff;}
nav .brand .logo{height:62px;width:auto;display:block;transition:height .4s var(--ease);}
nav.solid .brand .logo{height:52px;}
nav .brand .mark{width:30px;height:30px;border:2px solid var(--orange);position:relative;flex:0 0 auto;}
nav .brand .mark::before{content:'';position:absolute;inset:5px;border:1px solid rgba(255,255,255,.5);}
nav .brand .wm{display:flex;flex-direction:column;line-height:1;}
nav .brand .wm b{font-family:var(--cond);font-weight:300;letter-spacing:.28em;font-size:21px;}
nav .brand .wm span{font-family:var(--cond);font-weight:300;letter-spacing:.24em;font-size:8px;text-transform:uppercase;color:rgba(255,255,255,.42);margin-top:5px;}
nav ul{display:flex;gap:36px;list-style:none;margin:0;padding:0;}
nav ul a{font-family:var(--cond);font-weight:600;font-size:15px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.78);position:relative;padding-bottom:3px;}
nav ul a::after{content:'';position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--orange);transition:width .35s var(--ease);}
nav ul a:hover,nav ul a.active{color:#fff;}
nav ul a:hover::after,nav ul a.active::after{width:100%;}
.navcta{font-family:var(--cond);font-weight:700;font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.55);padding:11px 24px;transition:all .3s var(--ease);}
.navcta:hover{background:var(--orange);border-color:var(--orange);color:#fff;}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;}
.burger span{width:26px;height:2px;background:#fff;transition:.3s var(--ease);}
@media(max-width:1024px){
  nav ul,.navcta{display:none;}
  .burger{display:flex;}
  nav.open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  nav.open .burger span:nth-child(2){opacity:0;}
  nav.open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .mobnav{position:fixed;inset:0;z-index:190;background:rgba(10,10,10,.98);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 32px;transform:translateX(100%);transition:transform .5s var(--ease);}
  nav.open ~ .mobnav{transform:none;}
  .mobnav a{font-family:var(--serif);font-weight:700;font-size:40px;color:#fff;padding:10px 0;}
  .mobnav a span{color:var(--orange);}
}
.mobnav{display:none;}
@media(max-width:1024px){.mobnav{display:flex;}}

/* ---- buttons ---- */
.btn{font-family:var(--cond);font-weight:700;font-size:15px;letter-spacing:.12em;text-transform:uppercase;white-space:nowrap;
  padding:16px 38px;border:1px solid #fff;color:#fff;position:relative;overflow:hidden;isolation:isolate;transition:color .4s var(--ease);display:inline-flex;align-items:center;gap:10px;}
.btn::before{content:'';position:absolute;inset:0;background:#fff;transform:translateY(101%);transition:transform .4s var(--ease);z-index:-1;}
.btn:hover{color:var(--ink);}
.btn:hover::before{transform:translateY(0);}
.btn.solid{background:#fff;color:var(--ink);}
.btn.solid::before{background:var(--orange);}
.btn.solid:hover{color:#fff;}
.btn.ink{border-color:var(--ink);color:var(--ink);}
.btn.ink::before{background:var(--ink);}
.btn.ink:hover{color:#fff;}
.btn.orange{background:var(--orange);border-color:var(--orange);color:#fff;}
.btn.orange::before{background:var(--ink);}
.btn.orange:hover{color:#fff;border-color:var(--ink);}

/* ---- shared type ---- */
.eyebrow{font-family:var(--cond);font-weight:600;font-size:17px;letter-spacing:.26em;text-transform:uppercase;color:var(--grey-4);display:flex;align-items:center;gap:14px;}
.eyebrow.light{color:var(--grey-3);}
.eyebrow .bar{width:0;height:2px;background:var(--orange);transition:width 1s var(--ease) .2s;flex:0 0 auto;}
.in .eyebrow .bar,.show .eyebrow .bar{width:46px;}
.label{font-family:var(--cond);font-weight:700;font-size:14px;letter-spacing:.24em;text-transform:uppercase;color:var(--grey-4);}
.label .o{color:var(--orange);}

/* ---- hero (page header) ---- */
.hero{position:relative;overflow:hidden;background:var(--ink);}
.hero.full{height:100vh;min-height:680px;}
.hero.sub{min-height:62vh;display:flex;align-items:flex-end;}
.hero .bg{position:absolute;inset:-2%;background-size:cover;background-position:center;filter:grayscale(100%) brightness(.36) contrast(1.05);}
.hero.full .bg{animation:kenburns 20s ease-in-out infinite alternate;}
@keyframes kenburns{from{transform:scale(1.04) translate(0,0);}to{transform:scale(1.15) translate(-1.4%,-1.4%);}}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.34) 0%,rgba(0,0,0,.12) 40%,rgba(0,0,0,.8) 100%);}
.hero .edge{position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--orange);z-index:3;}
.hero .grain{position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.hero .inner{position:relative;z-index:2;color:#fff;width:100%;padding:0 var(--gutter) 88px;}
.hero.full .inner{position:absolute;left:0;right:0;bottom:0;}
.hero.sub .inner{padding-top:160px;}
.hero h1{font-family:var(--serif);font-weight:900;line-height:.9;letter-spacing:-.02em;margin:22px 0 0;text-shadow:0 2px 60px rgba(0,0,0,.5);}
.hero.full h1{font-size:clamp(3.2rem,9vw,8.6rem);}
.hero.sub h1{font-size:clamp(2.8rem,6vw,5.6rem);}
.hero h1 em{font-style:italic;color:var(--grey-3);}
.hero h1 .ln{display:block;overflow:hidden;padding-bottom:.16em;margin-bottom:-.16em;}
.hero h1 .ln i{display:block;font-style:normal;transform:translateY(105%);transition:transform 1s var(--ease);}
.hero h1 .ln:nth-child(2) i{transition-delay:.12s;}
.show .hero h1 .ln i,.hero.show h1 .ln i{transform:translateY(0);}
.hero .lede{max-width:500px;font-size:21px;font-weight:300;line-height:1.6;color:rgba(255,255,255,.74);margin:26px 0 0;opacity:0;transform:translateY(24px);transition:all .9s var(--ease) .45s;}
.show .hero .lede{opacity:1;transform:none;}
.hero .actions{display:flex;gap:16px;margin-top:34px;flex-wrap:wrap;opacity:0;transform:translateY(24px);transition:all .9s var(--ease) .6s;}
.show .hero .actions{opacity:1;transform:none;}
.scrollcue{position:absolute;right:var(--gutter);bottom:88px;z-index:2;display:flex;flex-direction:column;align-items:center;gap:12px;color:rgba(255,255,255,.6);}
.scrollcue span{font-family:var(--cond);font-size:11px;letter-spacing:.25em;text-transform:uppercase;writing-mode:vertical-rl;}
.scrollcue .l{width:1px;height:46px;background:rgba(255,255,255,.3);position:relative;overflow:hidden;}
.scrollcue .l::after{content:'';position:absolute;top:-46px;left:0;width:1px;height:46px;background:var(--orange);animation:cue 2s var(--ease) infinite;}
@keyframes cue{0%{top:-46px;}60%,100%{top:46px;}}

/* ---- marquee (condensed, not fluffy) ---- */
.marquee{background:var(--ink);color:var(--paper);border-top:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);overflow:hidden;padding:22px 0;}
.marquee .track{display:flex;white-space:nowrap;width:max-content;animation:scroll 30s linear infinite;}
.marquee:hover .track{animation-play-state:paused;}
.marquee .item{font-family:var(--cond);font-weight:700;font-size:19px;letter-spacing:.14em;text-transform:uppercase;padding:0 28px;display:flex;align-items:center;gap:28px;color:rgba(246,245,241,.92);}
.marquee .item::after{content:'';width:7px;height:7px;background:var(--orange);transform:rotate(45deg);flex:0 0 auto;}
@keyframes scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---- reveal util ---- */
.rv{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease);}
.rv.in{opacity:1;transform:none;}
.rv.d1{transition-delay:.08s;}.rv.d2{transition-delay:.16s;}.rv.d3{transition-delay:.24s;}.rv.d4{transition-delay:.32s;}

/* ---- layout helpers ---- */
section{padding:120px var(--gutter);}
.wrap{max-width:1500px;margin:0 auto;}
h2.big{font-family:var(--serif);font-weight:700;font-size:clamp(2.2rem,3.8vw,3.6rem);line-height:1.04;letter-spacing:-.01em;margin:18px 0 0;}
h2.big em{font-style:italic;color:var(--grey-4);}

/* ---- about split ---- */
.about{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:start;}
.about .sticky{position:sticky;top:120px;}
.about .body p{font-size:17px;line-height:1.85;color:var(--grey-6);margin:0 0 1.4rem;}
.about .body strong{font-weight:600;color:var(--ink);}
.quote{font-family:var(--serif);font-size:1.5rem;font-weight:400;line-height:1.5;color:var(--ink);padding-left:26px;position:relative;margin:2rem 0;}
.quote::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--orange);transform:scaleY(0);transform-origin:top;transition:transform .8s var(--ease);}
.quote.in::before{transform:scaleY(1);}
.signoff{font-family:var(--cond);font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-top:2rem;}
.signoff b{color:var(--orange);}
.frameimg{margin-top:30px;overflow:hidden;position:relative;}
.frameimg img{width:100%;height:340px;object-fit:cover;filter:grayscale(100%);transition:transform 1.4s var(--ease);}
.frameimg:hover img{transform:scale(1.06);}
.frameimg .tag{position:absolute;left:0;bottom:0;background:var(--orange);color:#fff;font-family:var(--cond);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;padding:8px 16px;}

/* ---- stats ---- */
.stats{background:var(--ink);color:var(--paper);display:grid;grid-template-columns:repeat(4,1fr);padding:0;}
.stats .cell{padding:70px 36px;border-right:1px solid var(--line-ink);}
.stats .cell:last-child{border-right:none;}
.stats .num{font-family:var(--serif);font-weight:900;font-size:clamp(3rem,5vw,4.6rem);line-height:1;}
.stats .cap{font-family:var(--cond);font-weight:600;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin-top:14px;}

/* ---- services grid (invert on hover) ---- */
.services .head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:54px;flex-wrap:wrap;}
.services h2{max-width:620px;}
.grid{border-top:1px solid var(--ink);display:grid;grid-template-columns:repeat(3,1fr);}
.grid.cols2{grid-template-columns:1fr 1fr;}
.grid.cols2 .cardc:nth-child(3n){border-right:1px solid var(--ink);}
.grid.cols2 .cardc:nth-child(2n){border-right:none;}
.cardc{position:relative;padding:46px 40px 52px;border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);cursor:pointer;overflow:hidden;background:var(--paper);}
.cardc:nth-child(3n){border-right:none;}
.cardc .fill{position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0;}
.cardc:hover .fill{transform:translateY(0);}
.cardc .topline{position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);transition:width .5s var(--ease);z-index:2;}
.cardc:hover .topline{width:100%;}
.cardc>*{position:relative;z-index:1;transition:color .45s var(--ease);}
.cardc .n{font-family:var(--cond);font-weight:700;font-size:13px;letter-spacing:.2em;color:var(--grey-4);margin-bottom:34px;}
.cardc:hover .n{color:var(--orange);}
.cardc h3{font-family:var(--serif);font-weight:700;font-size:1.6rem;margin:0 0 14px;}
.cardc p{font-size:15.5px;line-height:1.65;color:var(--grey-5);margin:0;}
.cardc .arr{margin-top:24px;font-family:var(--cond);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:13px;display:flex;align-items:center;gap:10px;opacity:0;transform:translateX(-8px);transition:all .45s var(--ease);color:var(--orange);}
.cardc:hover .arr{opacity:1;transform:none;}
.cardc:hover h3{color:#fff;}
.cardc:hover p{color:rgba(255,255,255,.66);}

/* ---- team / pillar band ---- */
.band{background:var(--ink-2);color:var(--paper);display:grid;grid-template-columns:1.1fr 1fr;gap:0;padding:0;align-items:stretch;}
.band .txt{padding:110px var(--gutter);}
.band h2{font-family:var(--serif);font-weight:700;font-size:clamp(2.2rem,3.6vw,3.4rem);line-height:1.06;margin:18px 0 0;}
.band h2 em{font-style:italic;color:var(--grey-3);}
.band p{font-size:18px;line-height:1.75;color:rgba(255,255,255,.66);margin:22px 0 0;max-width:480px;}
.band .img{background-size:cover;background-position:center;filter:grayscale(100%) brightness(.82);min-height:480px;position:relative;}
.band .img .edge{position:absolute;right:0;top:0;bottom:0;width:8px;background:var(--orange);}

/* ---- pillar list ---- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line-ink);}
.pillar{padding:42px 36px 48px;border-right:1px solid var(--line-ink);border-bottom:1px solid var(--line-ink);position:relative;cursor:pointer;transition:background .4s var(--ease);}
.pillar::before{content:'';position:absolute;top:0;left:0;height:3px;width:0;background:var(--orange);transition:width .5s var(--ease);}
.pillar:hover::before{width:100%;}
.pillar:hover{background:rgba(255,255,255,.045);}
.pillar:hover h3{color:var(--orange-soft);}
.pillar h3{transition:color .4s var(--ease);}
.pillars.on-ink .pillar:nth-child(3n){border-right:none;}
.pillar .n{font-family:var(--cond);font-weight:700;font-size:13px;letter-spacing:.2em;color:var(--orange);margin-bottom:26px;}
.pillar h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;margin:0 0 12px;color:#fff;}
.pillar p{font-size:15px;line-height:1.7;color:rgba(255,255,255,.6);margin:0;}

/* ---- list rows (services page / promises) ---- */
.rows{border-top:1px solid var(--ink);}
.row{display:grid;grid-template-columns:90px 1fr 1.3fr auto;gap:32px;align-items:center;padding:34px 0;border-bottom:1px solid var(--line);}
.row .rn{font-family:var(--serif);font-weight:900;font-size:1.8rem;color:var(--grey-3);}
.row h3{font-family:var(--serif);font-weight:700;font-size:1.7rem;margin:0;}
.row p{font-size:16px;line-height:1.6;color:var(--grey-5);margin:0;}
.row .go{font-family:var(--cond);font-weight:700;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);}

/* ---- meet the team ---- */
.teamgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;}
.tm{position:relative;overflow:hidden;background:var(--ink);}
.tm .topline{position:absolute;left:0;top:0;height:3px;width:0;background:var(--orange);z-index:3;transition:width .5s var(--ease);}
.tm:hover .topline{width:100%;}
.tm .photo{width:100%;aspect-ratio:3/4;overflow:hidden;background:var(--ink-2);}
.tm .photo img{width:100%;height:100%;object-fit:cover;object-position:top;filter:grayscale(100%);transition:transform .6s var(--ease),filter .6s;}
.tm:hover .photo img{transform:scale(1.04);filter:grayscale(60%);}
.tm h3{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:#fff;margin:24px 26px 4px;}
.tm .role{font-family:var(--cond);font-weight:600;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);margin:0 26px 16px;}
.tm .bio{font-size:14px;font-weight:300;line-height:1.75;color:rgba(255,255,255,.6);margin:0 26px 18px;}
.tm a.mail{display:inline-block;font-family:var(--sans);font-weight:300;font-size:15px;color:rgba(255,255,255,.7);margin:0 26px 30px;border-bottom:1px solid transparent;transition:color .3s,border-color .3s;}
.tm a.mail:hover{color:var(--orange);border-color:var(--orange);}

/* ---- CTA ---- */
.cta{background:var(--ink);color:var(--paper);text-align:center;padding:150px var(--gutter);position:relative;overflow:hidden;}
.cta::before,.cta::after{content:'';position:absolute;top:0;bottom:0;width:8px;background:var(--orange);}
.cta::before{left:0;}.cta::after{right:0;}
.cta h2{font-family:var(--serif);font-weight:900;font-size:clamp(2.4rem,5vw,5rem);line-height:1.02;margin:0 auto;max-width:900px;}
.cta h2 em{font-style:italic;color:var(--grey-3);}
.magnet{display:inline-block;margin-top:44px;}
.cta .btn{font-size:16px;padding:20px 52px;}

/* ---- contact ---- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.detail{display:flex;flex-direction:column;gap:6px;margin-bottom:30px;}
.detail .k{font-family:var(--cond);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);}
.detail .v{font-size:1.2rem;color:var(--ink);}
form.enq{background:var(--ink);padding:46px;position:relative;box-shadow:0 32px 70px -38px rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.08);}
form.enq::after{content:'';position:absolute;left:0;top:0;height:4px;width:100%;background:var(--orange);}
form.enq .fld{display:block;margin-bottom:26px;}
form.enq label{display:block;font-family:var(--cond);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:8px;}
form.enq input,form.enq select,form.enq textarea{width:100%;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.18);color:#fff;font-family:var(--sans);font-weight:300;font-size:1rem;padding:10px 0;outline:none;transition:border-color .3s;}
form.enq input:focus,form.enq select:focus,form.enq textarea:focus{border-color:var(--orange);}
form.enq option{color:#111;}
.sent{color:#fff;min-height:300px;display:flex;flex-direction:column;justify-content:center;}
.sent h3{font-family:var(--serif);font-weight:700;font-size:2rem;margin:.6rem 0 0;}

/* ---- footer ---- */
footer{background:var(--ink);color:var(--paper);padding:80px var(--gutter) 36px;border-top:1px solid var(--line-ink);}
.fcols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px;}
.fcols .bword{font-family:var(--cond);font-weight:300;letter-spacing:.30em;font-size:30px;}
.fcols .flogo{height:128px;width:auto;display:block;margin-bottom:4px;}
.fcols .bword .o{color:var(--orange);}
.fcols p{color:rgba(255,255,255,.45);font-size:12.5px;line-height:1.7;max-width:260px;margin:18px 0 0;}
.fcol h4{font-family:var(--cond);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin:0 0 22px;}
.fcol a{display:block;color:rgba(255,255,255,.62);font-size:14px;margin-bottom:12px;transition:color .25s;}
.fcol a:hover{color:var(--orange);}
.fbar{border-top:1px solid var(--line-ink);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.fbar span{font-family:var(--cond);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.35);}
.totop{cursor:pointer;}.totop:hover{color:var(--orange);}

/* ---- responsive ---- */
@media(max-width:1024px){
  :root{--gutter:28px;}
  section{padding:80px var(--gutter);}
  .hero.sub .inner{padding-top:130px;}
  .about{grid-template-columns:1fr;gap:48px;}.about .sticky{position:static;}
  .stats{grid-template-columns:repeat(2,1fr);}.stats .cell:nth-child(2){border-right:none;}
  .grid,.pillars{grid-template-columns:1fr;}.cardc{border-right:none!important;}
  .pillar{border-right:none!important;}
  .teamgrid{grid-template-columns:1fr 1fr;gap:24px;}
  .band{grid-template-columns:1fr;}.band .img{min-height:300px;}
  .contact{grid-template-columns:1fr;gap:40px;}form.enq{padding:32px;}
  .row{grid-template-columns:50px 1fr;gap:14px 18px;}.row p{grid-column:2;}.row .go{display:none;}
  .fcols{grid-template-columns:1fr 1fr;}
}
@media(max-width:600px){
  :root{--gutter:20px;}
  section{padding:60px var(--gutter);}
  nav{padding:16px var(--gutter);}
  nav .brand .logo{height:52px;}nav.solid .brand .logo{height:46px;}
  .hero.full{min-height:600px;}
  .hero .inner{padding-bottom:60px;}
  .hero.sub .inner{padding-top:118px;}
  .hero .lede{font-size:18px;}
  .hero .actions{gap:12px;}
  .btn{padding:14px 26px;font-size:14px;}
  .scrollcue{display:none;}
  .marquee{padding:16px 0;}
  .marquee .item{font-size:16px;padding:0 18px;gap:18px;}
  .stats{grid-template-columns:1fr 1fr;}
  .stats .cell{padding:40px 22px;}
  .stats .cell:nth-child(3){border-right:none;}
  .stats .cell:nth-child(1),.stats .cell:nth-child(2){border-bottom:1px solid var(--line-ink);}
  .about{gap:36px;}
  .frameimg img{height:260px;}
  .band .txt{padding:64px var(--gutter);}
  .cardc{padding:34px 26px 38px;}
  .pillar{padding:34px 26px 38px;}
  .tm{padding:0;}
  .teamgrid{grid-template-columns:1fr;gap:20px;}
  .cta{padding:90px var(--gutter);}
  .cta::before,.cta::after{width:5px;}
  .hero .edge{width:5px;}
  form.enq{padding:26px 22px;}
  .fcols{grid-template-columns:1fr;gap:36px;}
  .fcols .flogo{height:80px;}
  .fbar{flex-direction:column;align-items:flex-start;gap:14px;}
  .mobnav a{font-size:30px;}
  .quote{font-size:1.25rem;}
}
@media(prefers-reduced-motion:reduce){
  .hero .bg{animation:none;}.marquee .track{animation:none;}.scrollcue .l::after{animation:none;}
  .rv{opacity:1!important;transform:none!important;}
  .hero h1 .ln i,.hero .lede,.hero .actions{transform:none!important;opacity:1!important;}
}
